Condividi tramite


SLI_RECEIVE

Il verbo SLI_RECEIVE riceve risposte, comandi SNA e dati in un buffer di applicazioni luA (Microsoft® Windows® Logic Unit Application). SLI_RECEIVE fornisce anche lo stato corrente della sessione all'applicazione WINDOWS LUA.

La struttura seguente descrive il membro LUA_COMMON del blocco di controllo verbo (VCB) usato da SLI_RECEIVE.

Sintassi

  
struct LUA_COMMON {  
    unsigned short    lua_verb;  
    unsigned short    lua_verb_length;  
    unsigned short    lua_prim_rc;  
    unsigned long     lua_sec_rc;  
    unsigned short    lua_opcode;  
    unsigned long     lua_correlator;  
    unsigned char     lua_luname[8];  
    unsigned short    lua_extension_list_offset;  
    unsigned short    lua_cobol_offset;  
    unsigned long     lua_sid;  
    unsigned short    lua_max_length;  
    unsigned short    lua_data_length;  
    char FAR *        lua_data_ptr;  
    unsigned long     lua_post_handle;  
    struct LUA_TH     lua_th;  
    struct LUA_RH     lua_rh;  
    struct LUA_FLAG1  lua_flag1;  
    unsigned char     lua_message_type;  
    struct LUA_FLAG2  lua_flag2;   
    unsigned char     lua_resv56[7];  
    unsigned char     lua_encr_decr_option;  
};  

Members

lua_verb
Parametro fornito. Contiene il codice verbo, LUA_VERB_SLI per verbi SLI (Session Level Interface).

lua_verb_length
Parametro fornito. Specifica la lunghezza in byte del VCB LUA. Deve contenere la lunghezza del record verbo rilasciato.

lua_prim_rc
Codice restituito primario impostato da LUA al completamento del verbo. I codici restituiti validi variano a seconda del verbo LUA rilasciato.

lua_sec_rc
Codice restituito secondario impostato da LUA al completamento del verbo. I codici restituiti validi variano a seconda del verbo LUA rilasciato.

lua_opcode
Parametro fornito. Contiene il codice del comando LUA (codice operazione verbo) per l'emissione del verbo, LUA_OPCODE_SLI_RECEIVE.

lua_correlator
Parametro fornito. Contiene un valore fornito dall'utente che collega il verbo ad altre informazioni fornite dall'utente. LUA non usa o modifica queste informazioni. Questo parametro è facoltativo e,

lua_luname
Parametro fornito. Specifica il nome ASCII dell'LU locale usato dalla sessione LUA di Windows.

SLI_RECEIVE richiede solo questo parametro se lua_sid è zero.

Questo parametro è lungo otto byte, spaziato a destra con spazi (0x20) se il nome è più breve di otto caratteri.

lua_extension_list_offset
Non usato da SLI_RECEIVE e deve essere impostato su zero.

lua_cobol_offset
Non usato da LUA in Microsoft® Host Integration Server o SNA Server e deve essere zero.

lua_sid
Parametro fornito e restituito. Specifica l'identificatore di sessione e viene restituito da SLI_OPEN e RUI_INIT. Altri verbi usano questo parametro per identificare la sessione usata per il comando. Se altri verbi usano il parametro lua_luname per identificare le sessioni, impostare il parametro lua_sid su zero.

lua_max_length
Specifica la lunghezza del buffer ricevuto per RUI_READe SLI_RECEIVE.

lua_data_length
Parametro restituito. Specifica la lunghezza dei dati restituiti nel buffer di ricezione.

lua_data_ptr
Puntatore al buffer fornito dall'applicazione che deve ricevere i dati da un verbo SLI_RECEIVE . Entrambi i comandi SNA e i dati vengono inseriti in questo buffer e possono essere in un formato EBCDIC (Extended Binary Coded Decimal Interscambi Coded Decimal Coded).

Quando viene emesso SLI_RECEIVE, questo parametro punta alla posizione per ricevere i dati dall'host.

lua_post_handle
Parametro fornito. Usato in Microsoft® Windows Server se la notifica asincrona deve essere eseguita dagli eventi. Questa variabile contiene l'handle dell'evento da segnalare o un handle di finestra.

lua_th
Parametro restituito. Contiene l'intestazione di trasmissione SNA (TH) del messaggio ricevuto. Vengono restituiti vari sottoparametri per le funzioni di lettura e offerta. I relativi sottoparametri sono i seguenti:

lua_th.flags_fid

Formattare il tipo di identificazione 2, quattro bit.

lua_th.flags_mpf

Campo di mapping segmentazione, due bit. Definisce il tipo di segmento di dati. I valori seguenti sono validi:

0x0 segmento medio0x040x08 Segmento 0x0C Solo segmento 0x08

lua_th.flags_odai

Indicatore di assegnazione del campo indirizzo di origine-destinazione (OAF-DAF), un bit.

lua_th.flags_efi

Indicatore del flusso accelerato, un bit.

lua_th.daf

Campo indirizzo di destinazione (DAF), un carattere senza segno.

lua_th.oaf

Campo indirizzo di origine (OAF), un carattere senza segno.

lua_th.snf

Campo numero sequenza, un carattere senza segno[2].

lua_rh
Parametro restituito. Contiene l'intestazione richiesta/risposta SNA del messaggio inviato o ricevuto. I relativi sottoparametri sono i seguenti:

lua_rh.rri

Indicatore di risposta richiesta, un bit.

lua_rh.ruc

Categoria request/response unit (UR), due bit. I valori seguenti sono validi:

LUA_RH_FMD (0x00) Controllodel flusso di dati FMLUA_RH_NC(0x20) Controllo di rete LUA_RH_DFC (0x40) Controllo del flusso di datiLUA_RH_SC (0x60) Controllo sessione

lua_rh.fi

Indicatore di formato, un bit.

lua_rh.sdi

Indicatore di senso incluso, un bit.

lua_rh.bci

Indicatore della catena di inizio, un bit.

lua_rh.eci

Indicatore della catena di fine, un bit.

lua_rh.dr1i

Indicatore di risposta definito 1, un bit.

lua_rh.dr2i

Indicatore di risposta definito 2, un bit.

lua_rh.ri

Indicatore di risposta eccezione (per una richiesta) o indicatore del tipo di risposta (per una risposta), un bit.

lua_rh.qri

Indicatore di risposta in coda, un bit.

lua_rh.pi

Indicatore di pacing, un bit.

lua_rh.bbi

Inizio indicatore parentesi quadre, un bit.

lua_rh.ebi

Indicatore della parentesi quadre finale, un bit.

lua_rh.cdi

Indicatore di direzione di modifica, un bit.

lua_rh.csi

Indicatore di selezione del codice, un bit.

lua_rh.edi

Indicatore dati crittografato, un bit.

lua_rh.pdi

Indicatore dati spaziato, un bit.

lua_flag1
Parametro fornito. Contiene una struttura di dati contenente flag per i messaggi forniti dall'applicazione. Questo parametro viene usato da RUI_BID, RUI_READ, RUI_WRITE,SLI_BID, SLI_RECEIVE e SLI_SEND. I relativi sottoparametri sono i seguenti:

lua_flag1.bid_enable

Indicatore di abilitazione dell'offerta, un bit.

lua_flag1.close_abend

Chiudere l'indicatore immediato, un bit.

lua_flag1.nowait

Nessuna attesa per il flag di dati, un bit.

lua_flag1.sscp_exp

Flusso rapido del punto di controllo dei servizi di sistema (SSCP), un bit.

lua_flag1.sscp_norm

Flusso normale SSCP, un bit.

lua_flag1.lu_exp

Flusso rapido lu, un bit.

lua_flag1.lu_norm

Flusso normale lu, un bit.

Impostare lua_flag1.bid_enable su 1 per abilitare nuovamente l'SLI_BID più recente (equivalente all'emissione di SLI_BID con esattamente gli stessi parametri di prima) o impostarlo su zero se non si vuole riattivareSLI_BID. Si noti che l'abilitazione del SLI_BID precedente riutilizza il VCB originariamente allocato, quindi questo VCB non deve essere stato liberato o modificato.

Impostare lua_flag1.nowait su 1 per indicare che si vuole SLI_RECEIVE restituire immediatamente se i dati sono disponibili per essere letti o meno oppure impostarli su zero se si vuole che il verbo attenda i dati prima di restituire.

Impostare uno o più flag seguenti su 1 per indicare da quale flusso di messaggio leggere i dati:

lua_flag1.sscp_exp

lua_flag1.lu_exp

lua_flag1.sscp_norm

lua_flag1.lu_norm

Se vengono impostati più flag, vengono restituiti i dati con priorità più alta. L'ordine delle priorità (primo) è: SSCP accelerato, LU accelerato, normale SSCP, NORMALE LU. Il flag equivalente nel gruppo lua_flag2 è impostato per indicare da quale flusso sono stati letti i dati.

lua_message_type
Specifica il tipo di comandi ENA in ingresso o in uscita. Parametro restituito. Specifica il tipo di messaggio SNA indicato per SLI_RECEIVE. I valori possibili sono:

LUA_MESSAGE_TYPE_LU_DATA

LUA_MESSAGE_TYPE_SSCP_DATA

LUA_MESSAGE_TYPE_RSP

LUA_MESSAGE_TYPE_BID

LUA_MESSAGE_TYPE_BIND

LUA_MESSAGE_TYPE_BIS

LUA_MESSAGE_TYPE_CANCEL

LUA_MESSAGE_TYPE_CHASE

LUA_MESSAGE_TYPE_LUSTAT_LU

LUA_MESSAGE_TYPE_LUSTAT_SSCP

LUA_MESSAGE_TYPE_QC

LUA_MESSAGE_TYPE_QEC

LUA_MESSAGE_TYPE_RELQ

LUA_MESSAGE_TYPE_RTR

LUA_MESSAGE_TYPE_SBI

LUA_MESSAGE_TYPE_SIGNAL

LUA_MESSAGE_TYPE_STSN

SLI riceve e risponde alle richieste BIND e STSN tramite le routine di estensione dell'interfaccia LUA.

LU-DATA, LUSTAT_LU, LUSTAT_SSCP e SSCP_DATA non sono comandi SNA.

lua_flag2
Parametro restituito. Contiene flag per i messaggi restituiti da LUA. Restituito da RUI_BID, RUI_READ, RUI_WRITE, SLI_BID, SLI_RECEIVE e SLI_SEND. I relativi sottoparametri sono i seguenti:

lua_flag2.bid_enable

Indica che RUI_BID è stato abilitato nuovamente se impostato su 1.

lua_flag2.async

Indica che il verbo dell'interfaccia LUA è stato completato in modo asincrono se impostato su 1.

lua_flag2.sscp_exp

Indica il flusso rapido di SSCP se impostato su 1.

lua_flag2.sscp_norm

Indica il flusso normale di SSCP se impostato su 1.

lua_flag2.lu_exp

Indica il flusso rapido lu se impostato su 1.

lua_flag2.lu_norm

Indica il flusso normale lu se impostato su 1.

lua_resv56
Non usato da SLI_RECEIVE e deve essere impostato su zero.

lua_encr_decr_option
Non usato da SLI_RECEIVE e deve essere impostato su zero.

Codici restituiti

LUA_OK
Codice restituito primario; il verbo eseguito correttamente.

LUA_SEC_OK

Codice restituito secondario; nessuna informazione aggiuntiva per LUA_OK.

LUA_PARAMETER_CHECK
Codice restituito primario; il verbo non è stato eseguito a causa di un errore di parametro.

LUA_INVALID_LUNAME

Codice restituito secondario; è stato specificato un lua_luname non valido.

LUA_BAD_SESSION_ID

Codice restituito secondario; È stato specificato un valore non valido per lua_sid nel vcb.

LUA_BAD_DATA_PTR

Codice restituito secondario; il parametro lua_data_ptr non contiene un puntatore valido o non punta a un segmento di lettura/scrittura e sono necessari dati forniti.

LUA_RESERVED_FIELD_NOT_ZERO

Codice restituito secondario; Un parametro riservato per il verbo appena emesso non è impostato su zero.

LUA_INVALID_POST_HANDLE

Codice restituito secondario; per un sistema operativo Microsoft Windows che usa eventi come metodo di registrazione asincrona, windows LUA VCB non contiene un handle di evento valido.

LUA_BID_VERB_SEGMENT_ERROR

Codice restituito secondario; il buffer con il SLI_BID VCB è stato rilasciato prima dell'emissione del SLI_RECEIVE con lua_flag1.bid_enable impostato su 1.

LUA_NO_PREVIOUS_BID_ENABLED

Codice restituito secondario; SLI_BID non è stato emesso prima di emettere SLI_RECEIVE con lua_flag1.bid_enable.

LUA_BID_ALREADY_ENABLED

Codice restituito secondario; SLI_RECEIVE è stato rilasciato con lua_flag1.bid_enable quando SLI_BID era già attivo.

LUA_INVALID_FLOW

Codice restituito secondario; i flag di flusso lua_flag1 sono stati impostati in modo non corretto quando è stato emesso un verbo:

  • Quando si esegue SLI_SEND per inviare una risposta SNA, impostare un solo flag di flusso lua_flag1 .

  • Quando si esegue SLI_RECEIVE, impostare almeno un flag di flusso lua_flag1.

    LUA_VERB_LENGTH_INVALID

    Codice restituito secondario; Un verbo LUA è stato emesso con un valore per lua_verb_length imprevisto da LUA.

    LUA_STATE_CHECK
    Codice restituito primario; il verbo non è stato eseguito perché è stato emesso in uno stato non valido.

    LUA_NO_SLI_SESSION

    Codice restituito secondario; una sessione non è stata aperta o è stata inattiva a causa di un errore di SLI_CLOSE o di sessione quando è stato eseguito un comando.

    LUA_RECEIVE_ON_FLOW_PENDING

    Codice restituito secondario; un SLI_RECEIVE era ancora in sospeso quando questa applicazione ha emesso un altro SLI_RECEIVE per un flusso SNA.

    LUA_SESSION_FAILURE
    Codice restituito primario; una condizione di errore, specificata nel codice restituito secondario, ha causato l'esito negativo della sessione.

    LUA_RUI_WRITE_FAILURE

    Codice restituito secondario; è stato inviato un errore imprevisto al SLI da RUI_WRITE.

    LUA_RECEIVED_UNBIND

    Codice restituito secondario; L'unità logica primaria (PLU) ha inviato un comando SNA UNBIND all'interfaccia LUA quando una sessione era attiva. Di conseguenza, la sessione è stata arrestata.

    LUA_SLI_LOGIC_ERROR

    Codice restituito secondario; L'interfaccia LUA ha rilevato un errore interno nella logica.

    LUA_NO_RUI_SESSION

    Codice restituito secondario; non è stata inizializzata alcuna sessione per il verbo LUA emesso o un verbo diverso da SLI_OPEN è stato emesso prima dell'inizializzazione della sessione.

    LUA_MODE_INCONSISTENCY

    Codice restituito secondario; l'esecuzione di questa funzione non è consentita dallo stato corrente. La richiesta inviata al componente di metà sessione non è stata eseguita anche se è stata riconosciuta e supportata. Questo codice senso SNA è anche un codice di rilevamento delle richieste di eccezione.

    LUA_RECEIVER_IN_TRANSMIT_MODE

    Codice restituito secondario; Le risorse necessarie per gestire i dati del flusso normale non erano disponibili o lo stato della contesa half-duplex non è stato ricevuto quando è stata ricevuta una richiesta di flusso normale. Il risultato è una race condition. Questo codice senso SNA è anche un codice di rilevamento delle richieste di eccezione.

    LUA_LU_COMPONENT_DISCONNECTED

    Codice restituito secondario; un componente LU non è disponibile perché non è connesso correttamente. Assicurarsi che l'alimentazione sia attivata.

    LUA_FUNCTION_NOT_SUPPORTED

    Codice restituito secondario; LUA non supporta la funzione richiesta. È possibile che sia stato specificato un carattere di controllo, un parametro UR o un codice di richiesta formattato. Informazioni specifiche sul codice sense sono in byte 2 e 3.

    LUA_CHAINING_ERROR

    Codice restituito secondario; la sequenza delle impostazioni dell'indicatore della catena è in errore. È stata trovata un'intestazione di richiesta o un'unità richiesta non valida per il controllo sessione corrente o lo stato del controllo del flusso di dati. È stato impedito il recapito al componente di metà sessione.

    LUA_BRACKET

    Codice restituito secondario; il mittente non è riuscito a applicare le regole delle parentesi quadre di sessione. Si noti che le contese e le race condition sono esenti da questo errore. È stata trovata un'intestazione di richiesta o un'unità richiesta non valida per il controllo sessione corrente o lo stato del controllo del flusso di dati. È stato impedito il recapito al componente di metà sessione.

    LUA_DIRECTION

    Codice restituito secondario; mentre lo stato flip-flop half-duplex è stato NOT_RECEIVE, è stata ricevuta una richiesta di flusso normale. È stata trovata un'intestazione di richiesta o un'unità richiesta non valida per il controllo sessione corrente o lo stato del controllo del flusso di dati. È stato impedito il recapito al componente di metà sessione.

    LUA_DATA_TRAFFIC_QUIESCED

    Codice restituito secondario; È stata ricevuta una richiesta DFC (Data Flow Control) o FMD (Function Management Data) da una metà sessione che ha inviato un comando SHUTC o un comando QC e la richiesta DFC o FMD non ha risposto a un comando RELQ. È stata trovata un'intestazione di richiesta o un'unità richiesta non valida per il controllo sessione corrente o lo stato del controllo del flusso di dati. È stato impedito il recapito al componente di metà sessione.

    LUA_NO_BEGIN_BRACKET

    Codice restituito secondario; il ricevitore ha già inviato una risposta positiva a un comando BIS quando è stata ricevuta una richiesta BID o FMD che specifica BBI=BB. È stata trovata un'intestazione di richiesta o un'unità richiesta non valida per il controllo sessione corrente o lo stato di controllo del flusso di dati ricevuto. È stato impedito il recapito al componente di metà sessione.

    LUA_IMMEDIATE_REQUEST_MODE_ERROR

    Codice restituito secondario; la richiesta ha violato il protocollo di modalità richiesta immediata. È stata trovata una richiesta di intestazione o un'unità richiesta non valida per il controllo sessione corrente o lo stato di controllo del flusso di dati ricevuto. È stato impedito il recapito al componente di metà sessione.

    LUA_QUEUED_RESPONSE_ERROR

    Codice restituito secondario; la richiesta ha violato il protocollo di risposta in coda. È stata trovata una richiesta di intestazione o un'unità richiesta non valida per il controllo sessione corrente o lo stato di controllo del flusso di dati ricevuto. È stato impedito il recapito al componente di metà sessione.

    LUA_ERP_SYNC_EVENT_ERROR

    Codice restituito secondario; si è verificata una violazione del protocollo eventi sincrono ERP. È stata trovata una richiesta di intestazione o un'unità richiesta non valida per il controllo sessione corrente o lo stato di controllo del flusso di dati ricevuto. È stato impedito il recapito al componente di metà sessione.

    LUA_RSP_CORRELATION_ERROR

    Codice restituito secondario; è stata inviata una risposta che non corrisponde a una richiesta ricevuta in precedenza o è stata ricevuta una risposta che non corrisponde a una richiesta inviata in precedenza.

    LUA_RSP_PROTOCOL_ERROR

    Codice restituito secondario; È stata rilevata una violazione del protocollo di risposta nella risposta ricevuta dalla metà sessione primaria.

    LUA_BB_NOT_ALLOWED

    Codice restituito secondario; l'indicatore della parentesi quadra iniziale non è stato specificato correttamente. Le opzioni BIND scelte in precedenza o le regole architetturali sono state violate dai valori dei parametri dell'intestazione della richiesta. È stato impedito il recapito al componente di metà sessione. Gli errori non dipendono dallo stato della sessione corrente. È possibile che i mittenti non applichino le regole di sessione abbiano causato gli errori.

    LUA_EB_NOT CONSENTITO

    Codice restituito secondario; l'indicatore della parentesi quadra finale non è stato specificato correttamente. Le opzioni BIND scelte in precedenza o le regole architetturali sono state violate dai valori dei parametri dell'intestazione della richiesta. È stato impedito il recapito al componente di metà sessione. Gli errori non dipendono dallo stato della sessione corrente. È possibile che i mittenti non applichino le regole di sessione abbiano causato gli errori.

    LUA_EXCEPTION_RSP_NOT_ALLOWED

    Codice restituito secondario; quando non è stata consentita una risposta di eccezione, ne è stata richiesta una. Le opzioni BIND scelte in precedenza o le regole architetturali sono state violate dai valori dei parametri dell'intestazione della richiesta. È stato impedito il recapito al componente di metà sessione. Gli errori non dipendono dallo stato della sessione corrente. È possibile che i mittenti non applichino le regole di sessione abbiano causato gli errori.

    LUA_DEFINITE_RSP_NOT_ALLOWED

    Codice restituito secondario; quando non è stata consentita una risposta definita, ne è stata richiesta una. Le opzioni BIND scelte in precedenza o le regole architetturali sono state violate dai valori dei parametri dell'intestazione della richiesta. È stato impedito il recapito al componente di metà sessione. Gli errori non dipendono dallo stato della sessione corrente. È possibile che i mittenti non applichino le regole di sessione abbiano causato gli errori.

    LUA_CD_NOT_ALLOWED

    Codice restituito secondario; l'indicatore di direzione di modifica non è stato specificato correttamente. Le opzioni BIND scelte in precedenza o le regole architetturali sono state violate dai valori dei parametri dell'intestazione della richiesta. È stato impedito il recapito al componente di metà sessione. Gli errori non dipendono dallo stato della sessione corrente. È possibile che i mittenti non applichino le regole di sessione abbiano causato gli errori.

    LUA_NO_RESPONSE_NOT_ALLOWED

    Codice restituito secondario; una richiesta diversa da un EXR contiene una RISPOSTA NO. Le opzioni BIND scelte in precedenza o le regole architetturali sono state violate dai valori dei parametri dell'intestazione della richiesta. È stato impedito il recapito al componente di metà sessione. Gli errori non dipendono dallo stato della sessione corrente. È possibile che i mittenti non applichino le regole di sessione abbiano causato gli errori.

    LUA_CHAINING_NOT_SUPPORTED

    Codice restituito secondario; gli indicatori di concatenamento non sono stati specificati correttamente. Le opzioni BIND scelte in precedenza o le regole architetturali sono state violate dai valori dei parametri dell'intestazione della richiesta. È stato impedito il recapito al componente di metà sessione. Gli errori non dipendono dallo stato della sessione corrente. È possibile che i mittenti non applichino le regole di sessione abbiano causato gli errori.

    LUA_BRACKETS_NOT_SUPPORTED

    Codice restituito secondario; gli indicatori di parentesi quadre sono stati specificati in modo non corretto. Le opzioni BIND scelte in precedenza o le regole architetturali sono state violate dai valori dei parametri dell'intestazione della richiesta. È stato impedito il recapito al componente di metà sessione. Gli errori non dipendono dallo stato della sessione corrente. È possibile che i mittenti non applichino le regole di sessione abbiano causato gli errori.

    LUA_CD_NOT_SUPPORTED

    Codice restituito secondario; l'indicatore di direzione di modifica è stato impostato, ma LUA non supporta la direzione del cambiamento per questa situazione. Le opzioni BIND scelte in precedenza o le regole architetturali sono state violate dai valori dei parametri dell'intestazione della richiesta. È stato impedito il recapito al componente di metà sessione. Gli errori non dipendono dallo stato della sessione corrente. È possibile che i mittenti non applichino le regole di sessione abbiano causato gli errori.

    LUA_INCORRECT_USE_OF_FI

    Codice restituito secondario; l'indicatore di formato non è stato specificato correttamente. Le opzioni BIND scelte in precedenza o le regole architetturali sono state violate dai valori dei parametri dell'intestazione della richiesta. È stato impedito il recapito al componente di metà sessione. Gli errori non dipendono dallo stato della sessione corrente. È possibile che i mittenti non applichino le regole di sessione abbiano causato gli errori.

    LUA_ALTERNATE_CODE_NOT_SUPPORTED

    Codice restituito secondario; l'indicatore di selezione del codice è stato impostato, ma LUA non supporta la selezione del codice per questa sessione. Le opzioni BIND scelte in precedenza o le regole architetturali sono state violate dai valori dei parametri dell'intestazione della richiesta. È stato impedito il recapito al componente di metà sessione. Gli errori non dipendono dallo stato della sessione corrente. È possibile che i mittenti non applichino le regole di sessione abbiano causato gli errori.

    LUA_INCORRECT_RU_CATEGORY

    Codice restituito secondario; l'indicatore di categoria dell'unità richiesta non è stato specificato correttamente. Le opzioni BIND scelte in precedenza o le regole architetturali sono state violate dai valori dei parametri dell'intestazione della richiesta. È stato impedito il recapito al componente di metà sessione. Gli errori non dipendono dallo stato della sessione corrente. È possibile che i mittenti non applichino le regole di sessione abbiano causato gli errori.

    LUA_INCORRECT_REQUEST_CODE

    Codice restituito secondario; il codice della richiesta non è stato specificato correttamente. Le opzioni BIND scelte in precedenza o le regole architetturali sono state violate dai valori dei parametri dell'intestazione della richiesta. È stato impedito il recapito al componente di metà sessione. Gli errori non dipendono dallo stato della sessione corrente. È possibile che i mittenti non applichino le regole di sessione abbiano causato gli errori.

    LUA_INCORRECT_SPEC_OF_SDI_RTI

    Codice restituito secondario; L'SDI e l'RTI non sono stati specificati correttamente in una risposta. Le opzioni BIND scelte in precedenza o le regole architetturali sono state violate dai valori dei parametri dell'intestazione della richiesta. È stato impedito il recapito al componente di metà sessione. Gli errori non dipendono dallo stato della sessione corrente. È possibile che i mittenti non applichino le regole di sessione abbiano causato gli errori.

    LUA_INCORRECT_DR1I_DR2I_ERI

    Codice restituito secondario; dr1I, dr2I e L'ERI sono stati specificati in modo non corretto. Le opzioni BIND scelte in precedenza o le regole architetturali sono state violate dai valori dei parametri dell'intestazione della richiesta. È stato impedito il recapito al componente di metà sessione. Gli errori non dipendono dallo stato della sessione corrente. È possibile che i mittenti non applichino le regole di sessione abbiano causato gli errori.

    LUA_INCORRECT_USE_OF_QRI

    Codice restituito secondario; l'indicatore di risposta in coda non è stato specificato correttamente. Le opzioni BIND scelte in precedenza o le regole architetturali sono state violate dai valori dei parametri dell'intestazione della richiesta. È stato impedito il recapito al componente di metà sessione. Gli errori non dipendono dallo stato della sessione corrente. È possibile che i mittenti non applichino le regole di sessione abbiano causato gli errori.

    LUA_INCORRECT_USE_OF_EDI

    Codice restituito secondario; l'EDI è stato specificato in modo non corretto. Le opzioni BIND scelte in precedenza o le regole architetturali sono state violate dai valori dei parametri dell'intestazione della richiesta. È stato impedito il recapito al componente di metà sessione. Gli errori non dipendono dallo stato della sessione corrente. È possibile che i mittenti non applichino le regole di sessione abbiano causato gli errori.

    LUA_INCORRECT_USE_OF_PDI

    Codice restituito secondario; il PDI non è stato specificato correttamente. Le opzioni BIND scelte in precedenza o le regole architetturali sono state violate dai valori dei parametri dell'intestazione della richiesta. È stato impedito il recapito al componente di metà sessione. Gli errori non dipendono dallo stato della sessione corrente. È possibile che i mittenti non applichino le regole di sessione abbiano causato gli errori.

    LUA_UNSUCCESSFUL
    Codice restituito primario; il record verbo fornito è stato valido, ma il verbo non è stato completato correttamente.

    LUA_DATA_TRUNCATED

    Codice restituito secondario; i dati sono stati troncati perché i dati ricevuti erano più lunghi della lunghezza del buffer specificata in lua_max_length.

    LUA_DATA_SEGMENT_LENGTH_ERROR

    Codice restituito secondario; si è verificato uno dei seguenti elementi:

  • Il segmento di dati fornito per SLI_RECEIVE o SLI_SEND non è un segmento di dati di lettura/scrittura in base alle esigenze.

  • Il segmento di dati fornito per SLI_RECEIVE non è a lungo che fornito in lua_max_length.

  • Il segmento di dati fornito per SLI_SEND non è purché fornito in lua_data_length.

    LUA_NO_DATA

    Codice restituito secondario; nessun dato disponibile per la lettura quando SLI_RECEIVE contenente un parametro di attesa non è stato rilasciato.

    LUA_VERB_RECORD_SPANS_SEGMENTS

    Codice restituito secondario; il parametro di lunghezza VCB LUA e l'offset del segmento supera la fine del segmento.

    LUA_NOT_ACTIVE

    Codice restituito secondario; LUA non è stato attivo all'interno di Microsoft Host Integration Server o SNA Server quando è stato rilasciato un verbo LUA.

    LUA_NOT_READY

    Codice restituito secondario; uno dei seguenti ha causato la sospensione temporanea della sessione SLI:

  • È stato ricevuto un comando di tipo SNA UNBIND 0x02, che indica che è in arrivo un nuovo BINDING. Se il tipo UNBIND 0x02 viene ricevuto dopo il completamento della SLI_OPEN iniziale, la sessione viene sospesa fino a quando non viene ricevuto un flusso BIND, CRV e STSN facoltativo e SDT. Queste routine sono re-entranti perché devono essere chiamate di nuovo. La sessione viene ripresa dopo l'elaborazione del comando SDT. Se il tipo UNBIND 0x02 viene ricevuto mentre il SLI_OPEN sta ancora elaborando, il codice restituito primario è LUA_SESSION_FAILURE, non LUA_STATUS.

  • La ricezione di un SNA CLEAR ha causato la sospensione. La ricezione di un SNA SDT causerà la ripresa della sessione.

    LUA_SLI_LOGIC_ERROR

    Codice restituito secondario; l'interfaccia LUA ha rilevato un errore interno nella logica.

    LUA_INVALID_PROCESS

    Codice restituito secondario; la sessione per cui è stato rilasciato un verbo LUA non è disponibile perché un altro processo del sistema operativo/2 possiede la sessione.

    LUA_LU_INOPERATIVE

    Codice restituito secondario; si è verificato un errore grave durante il tentativo di arresto della sessione. Questa LU non è disponibile per le richieste LUA finché non viene ricevuta un'unità logica attiva (ACTLU) dall'host.

    LUA_RECEIVE_CORRELATION_TABLE_FULL

    Codice restituito secondario; la tabella di correlazione di ricezione della sessione per il flusso richiesto ha raggiunto la sua capacità.

    LUA_NEGATIVE_RESPONSE
    Codice restituito primario; LUA ha inviato una risposta negativa a un messaggio ricevuto dall'unità logica primaria (PLU) perché è stato rilevato un errore nel messaggio oppure l'applicazione ha risposto negativamente a una catena per cui è arrivata la fine della catena.

    LUA_MODE_INCONSISTENCY

    Codice restituito secondario; l'esecuzione di questa funzione non è consentita dallo stato corrente. La richiesta inviata al componente di metà sessione non è stata eseguita anche se è stata compresa e supportata. Questo codice di senso SNA è anche un codice di senso delle eccezioni.

    LUA_FUNCTION_NOT_SUPPORTED

    Codice restituito secondario; luA non supporta la funzione richiesta. Un carattere di controllo, un parametro UR o un codice di richiesta formattato potrebbe aver specificato la funzione. Informazioni specifiche sul codice di senso sono in byte 2 e 3.

    LUA_DATA_TRAFFIC_RESET

    Codice restituito secondario; una metà sessione di una sessione attiva, ma con traffico dati inattivo ha ricevuto una normale richiesta DFC o FMD del flusso. È stata trovata un'intestazione o un'unità richiesta non valida per il controllo sessione corrente o lo stato del flusso di dati. È stato impedito il recapito al componente di metà sessione.

    LUA_DATA_TRAFFIC_NOT_RESET

    Codice restituito secondario; mentre lo stato del traffico dati non è stato reimpostato, la richiesta di controllo sessione è stata ricevuta. È stata trovata un'intestazione di richiesta o un'unità richiesta non valida per lo stato di controllo del flusso di dati o del controllo della sessione corrente ricevuta. È stato impedito il recapito al componente di metà sessione.

    LUA_SC_PROTOCOL_VIOLATION

    Codice restituito secondario; si è verificata una violazione del protocollo SC. È stata ricevuta una richiesta (consentita solo dopo una richiesta SC e una risposta positiva a tale richiesta) prima dello scambio richiesto. Il byte 4 dei dati di senso contiene il codice della richiesta. Nessun dato utente esiste per questo codice di senso. È stata trovata una richiesta di intestazione o un'unità richiesta non valida per lo stato di controllo del flusso di dati o del controllo della sessione corrente. È stato impedito il recapito al componente di metà sessione.

    LUA_INVALID_SC_OR_NC_RH

    Codice restituito secondario; rh di una richiesta SC o NC non è valida.

    LUA_PACING_NOT_SUPPORTED

    Codice restituito secondario; la richiesta contiene un indicatore di pacing quando il supporto della pacing per questa sessione non esiste per la metà sessione o la funzione limite di ricezione metà sessione. Le opzioni BIND scelte in precedenza o le regole dell'architettura sono state violate dai valori dei parametri dell'intestazione della richiesta. È stato impedito il recapito al componente di metà sessione. Gli errori non dipendono dallo stato della sessione corrente. L'errore dei mittenti per applicare le regole di sessione potrebbe aver causato gli errori.

    LUA_NAU_INOPERATIVE

    Codice restituito secondario; l'unità indirizzabile di rete non è in grado di elaborare risposte o richieste. Il recapito al ricevitore non è stato possibile per uno dei motivi seguenti:

  • Errore dell'unità informazioni percorso

  • Interruzione del percorso

  • Sequenza non valida di richieste di attivazione

    Se viene ricevuto un errore di percorso durante una sessione attiva, in genere non esiste più un percorso valido per il partner sessione.

    LUA_CANCELED
    Codice restituito primario; il codice restituito secondario indica il motivo dell'annullamento del comando.

    LUA_PURGED

    Codice restituito secondario; SLI_PURGE è stato rilasciato e annullato SLI_RECEIVE.

    LUA_NO_SLI_SESSION

    Codice restituito secondario; una sessione non è stata aperta o è stata interrotta a causa di un errore di SLI_CLOSE o sessione quando è stato rilasciato un comando.

    LUA_CANCEL_COMMAND_RECEIVED

    Codice restituito secondario; l'host ha inviato un comando SNA CANCEL per annullare la catena di dati attualmente ricevuta da SLI_RECEIVE.

    LUA_TERMINATED

    Codice restituito secondario; la sessione è stata terminata quando un verbo era in sospeso. Il processo verbo è stato annullato.

    LUA_IN_PROGRESS
    Codice restituito primario; è stato ricevuto un comando asincrono ma non è stato completato.

    LUA_STATUS
    Codice restituito primario; il codice restituito secondario contiene informazioni sullo stato SLI per l'applicazione.

    LUA_READY

    Codice restituito secondario; seguendo uno stato NOT READY, questo stato viene rilasciato per notificare che il SLI è pronto per elaborare i comandi.

    LUA_NOT_READY

    Codice restituito secondario; la sessione SLI viene sospesa temporaneamente per il motivo seguente:

  • È stato ricevuto un comando di tipo SNA UNBIND 0x02, il che significa che verrà un nuovo BINDING. Se il tipo UNBIND 0x02 viene ricevuto dopo il completamento della SLI_OPEN iniziale, la sessione viene sospesa fino a quando non viene ricevuto un flusso BIND, CRV e STSN facoltativo e SDT. Queste routine sono re-entranti perché devono essere chiamate di nuovo. La sessione viene ripresa dopo l'elaborazione del comando SDT. Se il tipo UNBIND 0x02 viene ricevuto durante l'elaborazione dell'SLI_OPEN , il codice restituito primario è un errore di sessione, non lo stato.

  • La ricezione di un SNA CLEAR ha causato la sospensione. La ricezione di un SNA SDT causerà la ripresa della sessione.

    LUA_INIT_COMPLETE

    Codice restituito secondario; l'interfaccia LUA inizializza la sessione durante l'elaborazione di SLI_OPEN . Applicazioni LUA che emettono SLI_OPEN con lua_open_type_prim_sscp ricevono questo stato in SLI_RECEIVE o SLI_BID.

    LUA_SESSION_END_REQUESTED

    Codice restituito secondario; l'interfaccia LUA ha ricevuto un SNA SHUTD dall'host, il che significa che l'host è pronto per arrestare la sessione.

    LUA_COMM_SUBSYSTEM_ABENDED
    Codice restituito primario; indica una delle condizioni seguenti:

  • Il nodo usato da questa conversazione ha rilevato un ABEND.

  • La connessione tra il programma di transazione (TP) e l'unità fisica (PU) 2.1 nodo è stato interrotto (errore LAN).

  • Il SnaBase nel computer TP ha rilevato un ABEND.

    LUA_COMM_SUBSYSTEM_NOT_LOADED
    Codice restituito primario; Impossibile caricare o terminare un componente obbligatorio durante l'elaborazione del verbo. Pertanto, la comunicazione non poteva essere eseguita. Contattare l'amministratore di sistema per un'azione correttiva.

    LUA_INVALID_VERB_SEGMENT
    Codice restituito primario; VCB esteso oltre la fine del segmento di dati.

    LUA_UNEXPECTED_DOS_ERROR
    Codice restituito primario; dopo l'emissione di una chiamata al sistema operativo, è stato ricevuto un codice restituito del sistema operativo imprevisto e viene specificato nel codice restituito secondario.

    LUA_STACK_TOO_SMALL
    Codice restituito primario; le dimensioni dello stack dell'applicazione sono troppo piccole per eseguire il verbo. Aumentare le dimensioni dello stack dell'applicazione.

    LUA_INVALID_VERB
    Codice restituito primario; il codice verbo o il codice dell'operazione, o entrambi, non è valido. Il verbo non è stato eseguito.

Commenti

SLI_RECEIVE riceve risposte, comandi SNA e dati dell'unità richiesta dall'host. SLI_RECEIVE fornisce anche lo stato della sessione all'applicazione Windows LUA. Una richiesta di SLI_OPEN deve essere completata prima che sia possibile eseguire SLI_RECEIVE . Tuttavia, se SLI_OPEN viene rilasciato con lua_init_type impostato su LUA_INIT_TYPE_PRIM_SSCP, un SLI_RECEIVE sul flusso normale SSCP può essere rilasciato non appena SLI_OPENrestituisce un IN_PROGRESS.

I dati vengono ricevuti dall'applicazione in uno dei quattro flussi di sessione. I quattro flussi di sessione, dal più alto al più basso sono:

  • SSCP accelerato

  • LU accelerato

  • SSCP normale

  • Normale lu

    Il tipo di flusso di dati che SLI_RECEIVE verrà elaborato viene specificato in lua_flag1. L'applicazione può anche specificare se vuole esaminare più tipi di flusso di dati. Quando vengono impostati più bit di flusso, viene ricevuta prima la priorità più alta. Quando SLI_RECEIVE completa l'elaborazione, lua_flag2 indica il tipo di flusso specifico per cui i dati sono stati ricevuti dall'applicazione Windows LUA.

    Se SLI_BID viene completato correttamente prima dell'emissione di SLI_RECEIVE , l'interfaccia LUA di Windows può essere incaricata di riutilizzare l'ultima SLI_BID verbi VCB. A tale scopo, eseguire SLI_RECEIVE con lua_flag1.bid_enable impostato su 1.

    Quando si usa lua_flag1.bid_enable, l'archiviazione di SLI_BID non deve essere liberata perché viene usato l'ultimo verbo VCB SLI_BID. Inoltre, quando si usa lua_flag1.bid_enable, verrà pubblicato il completamento corretto di SLI_BID.

    Se SLI_RECEIVE viene rilasciato con lua_flag1.nowait quando non sono disponibili dati per la ricezione, LUA_NO_DATA sarà il codice restituito secondario impostato dall'interfaccia LUA di Windows.

Valori restituiti stato sessione

Se LUA_STATUS è il codice restituito primario, il codice restituito secondario può essere uno dei seguenti:

LUA_READY

LUA_NOT_READY

LUA_SESSION_END_REQUESTED

LUA_INIT_COMPLETE

Inoltre, se LUA_STATUS è il codice restituito primario, vengono usati i parametri seguenti:

lua_sec_rc

lua_sid

LUA_READY viene restituito dopo uno stato di LUA_NOT_READY e indica che SLI è nuovamente pronto per eseguire tutti i comandi.

LUA_NOT_READY indica che la sessione SLI viene sospesa perché SLI ha ricevuto un comando SNA CLEAR o un comando SNA UNBIND con un 0x02 tipo UNBIND (UNBIND con BIND in futuro). A seconda di ciò che ha causato la sospensione, la sessione può essere riattivata come segue:

  • Quando la sospensione viene causata da una SNA CLEAR, la ricezione di una SNA SDT reagisce alla sessione.

  • Quando un tipo SNA UNBIND BIND in futuro causa la sospensione della sessione e la SLI_OPEN che ha aperto la sessione viene completata, la sessione viene sospesa fino a quando il SLI riceve un comando BIND e SDT. La sessione può anche ricevere facoltativamente un comando STSN. Di conseguenza, le routine fornite dall'utente rilasciate con il SLI_OPEN iniziale devono essere nuovamente immesse perché verranno richiamate.

    L'applicazione può inviare dati SSCP dopo l'arrivo di un tipo CLEAR o UNBIND BIND e prima della lettura dello stato NOT_READY. L'applicazione può inviare e ricevere dati SSCP dopo aver letto un NOT_READY.

    Quando un tipo SNA UNBIND BIND arriverà prima del completamento della SLI_OPEN che ha aperto la sessione, LUA_SESSION_FAILURE (non LUA_STATUS) è il codice restituito primario.

    LUA_SESSION_END_REQUESTED indica che l'applicazione ha ricevuto un SNA SHUTD dall'host. L'applicazione WINDOWS LUA deve eseguire SLI_CLOSE per chiudere la sessione quando è conveniente.

    LUA_INIT_COMPLETE viene restituito solo quando lua_init_type per SLI_OPEN è LUA_INIT_TYPE_PRIM_SSCP. Lo stato indica che la SLI_OPEN è stata elaborata in modo sufficiente per consentire l'invio o la ricezione dei dati SSCP.

Richieste di eccezione

Se un'unità richiesta dell'applicazione host viene convertita in un exR, i dati di senso verranno restituiti. Quando SLI_BID viene completato con i parametri verbi restituiti impostati come illustrato, si verifica una conversione EXR.

Membro Impostare su
lua_prim_rc OK (0x0000)
lua_sec_rc OK (0x00000000)
lua_rh.rri bit off (unità richiesta)
lua_rh.sdi bit on (include dati di senso)

Di sette byte di dati in lua_peek_data, byte da 0 a 3 definiscono l'errore rilevato. La tabella seguente indica i dati di senso possibili e i valori di byte da 0 a 3.

Dati di senso Valore di byte da 0 a 3
LUA_MODE_INCONSISTENCY 0x08090000
LUA_BRACKET_RACE_ERROR 0x080B0000
LUA_BB_REJECT_NO_RTR 0x08130000
LUA_RECEIVER_IN_TRANSMIT_MODE 0x081B0000
LUA_CRYPTOGRAPHY_FUNCTION_INOP 0x08480000
LUA_SYNC_EVENT_RESPONSE 0x10010000
LUA_RU_DATA_ERROR 0x10020000
LUA_RU_LENGTH_ERROR 0x10020000
LUA_INCORRECT_SEQUENCE_NUMBER 0x20010000

Le informazioni restituite ai byte da 3 a 6 in lua_peek_data sono determinate dai primi tre byte dell'unità richiesta iniziale che ha causato l'errore.

Vedere anche

RUI_INIT
RUI_PURGE
RUI_READ
RUI_WRITE
SLI_BID
SLI_CLOSE
SLI_OPEN
SLI_PURGE
SLI_SEND