Hinweis
Für den Zugriff auf diese Seite ist eine Autorisierung erforderlich. Sie können versuchen, sich anzumelden oder das Verzeichnis zu wechseln.
Für den Zugriff auf diese Seite ist eine Autorisierung erforderlich. Sie können versuchen, das Verzeichnis zu wechseln.
Das SEND_DATA Verb platziert Daten im LU-Sendepuffer (LU) der lokalen logischen Einheit für die Übertragung an das Partnertransaktionsprogramm (TP).
In der folgenden Struktur wird der verbsteuerungsblock (VCB) beschrieben, der vom SEND_DATA Verb verwendet wird.
Syntax
struct send_data {
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 char rts_rcvd;
unsigned char data_type;
unsigned short int dlen;
unsigned char FAR * dptr ;
unsigned char type;
unsigned char reserv4;
};
Elemente
opcode
Angegebener Parameter. Gibt den Verbvorgangscode AP_B_SEND_DATA an.
opext
Angegebener Parameter. Gibt die Verbvorgangserweiterung AP_BASIC_CONVERSATION an.
reserv2
Ein reserviertes Feld.
primary_rc
Zurückgegebener Parameter. Gibt den primären Rückgabecode an, der von APPC am Ende des Verbs festgelegt wurde. Die gültigen Rückgabecodes variieren je nach ausgegebenen APPC-Verb. Informationen zu gültigen Fehlercodes für dieses Verb finden Sie unter "Rückgabecodes".
secondary_rc
Zurückgegebener Parameter. Gibt den von APPC festgelegten sekundären Rückgabecode am Ende des Verbs an. Die gültigen Rückgabecodes variieren je nach ausgegebenen APPC-Verb. Informationen zu gültigen Fehlercodes für dieses Verb finden Sie unter "Rückgabecodes".
tp_id
Angegebener Parameter. Identifiziert das lokale TP.
Der Wert dieses Parameters wird von TP_STARTED im aufrufenden TP oder von RECEIVE_ALLOCATE im aufgerufenen TP zurückgegeben.
conv_id
Angegebener Parameter. Stellt den Unterhaltungsbezeichner bereit.
Der Wert dieses Parameters wird von ALLOCATE im aufgerufenen TP oder von RECEIVE_ALLOCATE im aufgerufenen TP zurückgegeben.
rts_rcvd
Zurückgegebener Parameter. Stellt den Anforderungs-zu-Sende-Empfangen-Indikator bereit.
AP_YES gibt an, dass der Partner-TP REQUEST_TO_SEND ausgestellt hat, was anfordert, dass die lokale TP die Unterhaltung in den EMPFANGSstatus ändert. Um in den EMPFANGSzustand zu wechseln, kann der lokale TP PREPARE_TO_RECEIVE, RECEIVE_AND_WAIT oder RECEIVE_AND_POST verwenden.
AP_NO weist darauf hin, dass der Partner-TP keine REQUEST_TO_SEND ausgestellt hat.
data_type
Angegebener Parameter. Gibt den Typ der zu sendenden Daten an, wenn der Synchronisierungspunkt unterstützt wird. Gültige Parameter sind:AP_APPLICATION
AP_USER_CONTROL_DATA
AP_PS_HEADER
dlen
Angegebener Parameter. Gibt die Anzahl der Bytes an, die in den Sendepuffer der lokalen LU eingefügt werden sollen. Der Bereich liegt zwischen 0 und 65535.dptr
Angegebener Parameter. Gibt die Adresse des Puffers an, der die Daten enthält, die im Sendepuffer der lokalen LU platziert werden sollen.Für das Microsoft Windows-Betriebssystem kann sich der Datenpuffer in einem statischen Datenbereich oder in einem global zugewiesenen Bereich befinden. Der Datenpuffer muss vollständig in diesen Bereich passen.
Typ
Angegebener Parameter. Ermöglicht einem TP, Daten zu senden und andere Funktionen innerhalb eines API-Aufrufs auszuführen. Sie können z. B. SEND_DATA mit typsatz "CONFIRM" kombinieren, um dasselbe Ziel wie das Ausstellen von SEND_DATA gefolgt von CONFIRM zu erreichen.AP_SEND_DATA_CONFIRM entspricht SEND_DATA gefolgt von CONFIRM.
AP_SEND_DATA_FLUSH entspricht SEND_DATA gefolgt von FLUSH.
AP_SEND_DATA_DEALLOC_ABEND entspricht SEND_DATAgefolgt von DEALLOCATE mit einem dealloc_type von AP_ABEND_PROG.
AP_SEND_DATA_DEALLOC_FLUSH entspricht SEND_DATAgefolgt von DEALLOCATE mit einem dealloc_type von AP_FLUSH.
AP_SEND_DATA_DEALLOC_SYNC_LEVEL entspricht SEND_DATAgefolgt von DEALLOCATE mit einem dealloc_type von AP_SYNC_LEVEL.
AP_SEND_DATA_P_TO_R_FLUSH entspricht SEND_DATA gefolgt von PREPARE_TO_RECEIVE mit einem ptr_type AP_FLUSH.
AP_SEND_DATA_P_TO_R_SYNC_LEVEL entspricht SEND_DATA gefolgt von PREPARE_TO_RECEIVE mit einer ptr_type von AP_SYNC_LEVEL und Sperren , die auf AP_SHORT festgelegt sind.
reserv4
Ein reserviertes Feld.
Rückgabecodes
AP_OK
Primärer Rückgabecode; das Verb erfolgreich ausgeführt wurde.
AP_PARAMETER_CHECK
Primärer Rückgabecode; das Verb wurde aufgrund eines Parameterfehlers nicht ausgeführt.
AP_BAD_CONV_ID
Sekundärer Rückgabecode; der Wert von conv_id nicht mit einem Unterhaltungsbezeichner übereinstimmt, der von APPC zugewiesen wurde.
AP_BAD_LL
Sekundärer Rückgabecode; Das Feld mit der Länge eines logischen Datensatzes enthielt einen ungültigen Wert – 0x0000, 0x0001, 0x8000 oder 0x8001. Informationen zu logischen Datensätzen finden Sie unter "Über Transaktionsprogramme ".
AP_BAD_TP_ID
Sekundärer Rückgabecode; der Wert von tp_id nicht mit einem TP-Bezeichner übereinstimmt, der von APPC zugewiesen wurde.
AP_INVALID_DATA_SEGMENT
Sekundärer Rückgabecode; Die für den Datenpuffer angegebene Länge war länger als das Segment, das dem Puffer zugeordnet ist.
AP_SEND_DATA_INVALID_TYPE
Sekundärer Rückgabecode; der angegebene Typ wurde von APPC nicht erkannt.
AP_SEND_DATA_CONFIRM_SYNC_NONE
Sekundärer Rückgabecode; der Typ CONFIRM ist für eine Unterhaltung, die einem sync_level NONE zugeordnet wurde, nicht zulässig.
AP_STATE_CHECK
Primärer Rückgabecode; das Verb wurde nicht ausgeführt, weil es in einem ungültigen Zustand ausgegeben wurde.
AP_SEND_DATA_NOT_SEND_STATE
Sekundärer Rückgabecode; Das lokale TP hat SEND_DATA ausgestellt, aber die Unterhaltung war nicht im SEND-Zustand.
AP_SEND_DATA_NOT_LL_BDY
Sekundärer Rückgabecode; der TP gestartet wurde, aber das Senden eines logischen Datensatzes nicht abgeschlossen hat. Dies tritt nur auf, wenn der Typparameter einer der folgenden Werte ist:
AP_SEND_DATA_CONFIRM
AP_SEND_DATA_DEALLOC_FLUSH
AP_SEND_DATA_DEALLOC_SYNC_LEVEL
AP_SEND_DATA_P_TO_R_FLUSH
AP_SEND_DATA_P_TO_R_SYNC_LEVEL
AP_ALLOCATION_ERROR
Primärer Rückgabecode; APPC konnte eine Unterhaltung nicht zuordnen. Der Unterhaltungszustand ist auf RESET festgelegt.
Dieser Code kann über ein Verb zurückgegeben werden, das nach ZUWEISUNG ausgegeben wurde.
AP_ALLOCATION_FAILURE_NO_RETRY
Sekundärer Rückgabecode; die Unterhaltung kann aufgrund einer dauerhaften Bedingung nicht zugewiesen werden, z. B. aufgrund eines Konfigurationsfehlers oder sitzungsprotokollfehlers. Um den Fehler zu ermitteln, sollte der Systemadministrator die Fehlerprotokolldatei untersuchen. Wiederholen Sie die Zuordnung erst, wenn der Fehler behoben wurde.
AP_ALLOCATION_FAILURE_RETRY
Sekundärer Rückgabecode; die Unterhaltung konnte aufgrund einer temporären Bedingung, z. B. aufgrund eines Verknüpfungsfehlers, nicht zugewiesen werden. Der Grund für den Fehler wird im Systemfehlerprotokoll protokolliert. Wiederholen Sie die Zuordnung.
AP_CONVERSATION_TYPE_MISMATCH
Sekundärer Rückgabecode; die Partner-LU oder TP unterstützt den in der Zuordnungsanforderung angegebenen Unterhaltungstyp (einfach oder zugeordnet) nicht.
AP_PIP_NOT_ALLOWED
Sekundärer Rückgabecode; Die zuordnungsanforderung angegebene PIP-Daten, aber entweder der Partner TP erfordert diese Daten nicht, oder die Partner-LU unterstützt sie nicht.
AP_PIP_NOT_SPECIFIED_CORRECTLY
Sekundärer Rückgabecode; Der Partner-TP erfordert PIP-Daten, aber die Zuordnungsanforderung hat entweder keine PIP-Daten oder eine falsche Anzahl von Parametern angegeben.
AP_SECURITY_NOT_VALID
Sekundärer Rückgabecode; Die in der Zuordnungsanforderung angegebene Benutzer-ID oder das kennwort wurde von der Partner-LU nicht akzeptiert.
AP_SYNC_LEVEL_NOT_SUPPORTED
Sekundärer Rückgabecode; der Partner-TP unterstützt die in der Zuordnungsanforderung angegebenen sync_level (AP_NONE oder AP_CONFIRM_SYNC_LEVEL) nicht, oder die sync_level wurde nicht erkannt.
AP_TP_NAME_NOT_RECOGNIZED
Sekundärer Rückgabecode; die Partner-LU erkennt den in der Zuordnungsanforderung angegebenen TP-Namen nicht.
AP_TRANS_PGM_NOT_AVAIL_NO_RETRY
Sekundärer Rückgabecode; die Remote-LU hat die Zuordnungsanforderung abgelehnt, da sie den angeforderten Partner-TP nicht starten konnte. Die Bedingung ist dauerhaft. Der Grund für den Fehler kann auf dem Remoteknoten protokolliert werden. Wiederholen Sie die Zuordnung erst, wenn der Fehler behoben wurde.
AP_TRANS_PGM_NOT_AVAIL_RETRY
Sekundärer Rückgabecode; die Remote-LU hat die Zuordnungsanforderung abgelehnt, da sie den angeforderten Partner-TP nicht starten konnte. Die Bedingung kann vorübergehend sein, z. B. ein Timeout. Der Grund für den Fehler kann auf dem Remoteknoten protokolliert werden. Wiederholen Sie die Zuordnung.
AP_COMM_SUBSYSTEM_ABENDED
Primärer Rückgabecode; gibt eine der folgenden Bedingungen an:
Der von dieser Unterhaltung verwendete Knoten hat einen ABEND gefunden.
Die Verbindung zwischen dem TP und dem PU 2.1-Knoten wurde unterbrochen (LAN-Fehler).
Die SnaBase auf dem Computer des TP ist ein ABEND aufgetreten.
Der Systemadministrator sollte das Fehlerprotokoll untersuchen, um den Grund für den ABEND zu ermitteln.
AP_COMM_SUBSYSTEM_NOT_LOADED
Primärer Rückgabecode; Eine erforderliche Komponente konnte nicht geladen oder beendet werden, während das Verb verarbeitet wird. So konnte die Kommunikation nicht stattfinden. Wenden Sie sich an den Systemadministrator, um Korrekturmaßnahmen zu ergreifen.Wenn dieser Rückgabecode mit ALLOCATE verwendet wird, kann es darauf hindeuten, dass kein Kommunikationssystem gefunden werden konnte, um die lokale LU zu unterstützen. (Der mit TP_STARTED angegebene lokale LU-Alias ist beispielsweise falsch oder wurde nicht konfiguriert.) Wenn lu_alias oder mode_name weniger als acht Zeichen enthält, müssen Sie sicherstellen, dass diese Felder mit Leerzeichen rechts gefüllt sind. Dieser Fehler wird zurückgegeben, wenn diese Parameter nicht mit Leerzeichen gefüllt sind, da kein Knoten verfügbar ist, der die ALLOCATE-Anforderung erfüllen kann.
Wenn ALLOCATE diesen Rückgabecode für ein Hostintegrationsserver-Clientsystem erzeugt, das mit mehreren Knoten konfiguriert ist, gibt es zwei sekundäre Rückgabecodes wie folgt:
0xF0000001
Sekundärer Rückgabecode; es wurden keine Knoten gestartet.
0xF0000002
Sekundärer Rückgabecode; mindestens ein Knoten wurde gestartet, aber die lokale LU (wenn TP_STARTED ausgegeben wird) ist für keine aktiven Knoten konfiguriert. Das Problem könnte eine der folgenden sein:
Der Knoten mit der lokalen LU wird nicht gestartet.
Die lokale LU ist nicht konfiguriert.
AP_CONV_FAILURE_NO_RETRY
Primärer Rückgabecode; Die Unterhaltung wurde aufgrund einer dauerhaften Bedingung beendet, z. B. aufgrund eines Sitzungsprotokollfehlers. Der Systemadministrator sollte das Systemfehlerprotokoll untersuchen, um die Ursache des Fehlers zu ermitteln. Wiederholen Sie die Unterhaltung erst, wenn der Fehler behoben wurde.AP_CONV_FAILURE_RETRY
Primärer Rückgabecode; Die Unterhaltung wurde aufgrund eines temporären Fehlers beendet. Starten Sie den TP neu, um festzustellen, ob das Problem erneut auftritt. Wenn dies der Fall ist, sollte der Systemadministrator das Fehlerprotokoll untersuchen, um die Ursache des Fehlers zu ermitteln.AP_CONVERSATION_TYPE_MIXED
Primärer Rückgabecode; das TP sowohl grundlegende als auch zugeordnete Unterhaltungsverben ausgestellt hat. In einer einzigen Unterhaltung kann nur ein Typ ausgegeben werden.AP_INVALID_VERB_SEGMENT
Primärer Rückgabecode; die VCB über das Ende des Datensegments hinaus erweitert wurde.AP_PROG_ERROR_PURGING
Primärer Rückgabecode; während der Status "RECEIVE", "PENDING", "PENDING_POST", "CONFIRM", "CONFIRM_SEND" oder "CONFIRM_DEALLOCATE" hat der Partner-TP SEND_ERROR ausgestellt, wobei err_type auf AP_PROG festgelegt ist. Gesendete, aber noch nicht empfangene Daten werden gelöscht.AP_STACK_TOO_SMALL
Primärer Rückgabecode; Die Stapelgröße der Anwendung ist zu klein, um das Verb auszuführen. Erhöhen Sie die Stapelgröße Ihrer Anwendung.AP_CONV_BUSY
Primärer Rückgabecode; es kann jeweils nur ein herausragendes Unterhaltungsverb für jede Unterhaltung vorhanden sein. Dies kann auftreten, wenn der lokale TP über mehrere Threads verfügt und mehrere Threads APPC-Aufrufe mit demselben conv_id ausgeben.AP_THREAD_BLOCKING
Primärer Rückgabecode; Der aufrufende Thread befindet sich bereits in einem blockierenden Aufruf.AP_UNEXPECTED_DOS_ERROR
Primärer Rückgabecode; Das Betriebssystem hat beim Verarbeiten eines APPC-Aufrufs vom lokalen TP einen Fehler an APPC zurückgegeben. Der Rückgabecode des Betriebssystems wird über die secondary_rc zurückgegeben. Es wird in intel byte-getauschter Reihenfolge angezeigt. Wenn das Problem weiterhin besteht, wenden Sie sich an den Systemadministrator.AP_DEALLOC_ABEND_PROG
Primärer Rückgabecode; die Unterhaltung wurde aus einem der folgenden Gründe umgestellt:Der Partner-TP hat DEALLOCATE mit dealloc_type auf AP_ABEND_PROG festgelegt.
Der Partner TP hat einen ABEND gefunden, der dazu führt, dass der Partner LU eine DEALLOCATE-Anforderung sendet.
AP_DEALLOC_ABEND_SVC
Primärer Rückgabecode; die Unterhaltung wurde abgeglichen, da der Partner TP DEALLOCATE mit dealloc_type auf AP_ABEND_SVC festgelegt hat.AP_DEALLOC_ABEND_TIMER
Primärer Rückgabecode; die Unterhaltung wurde zugeordnet, da der Partner TP DEALLOCATE mit dealloc_type auf AP_ABEND_TIMER festgelegt hat.AP_SVC_ERROR_PURGING
Primärer Rückgabecode; der Partner TP (oder partner LU) hat ein SEND_ERROR Verb ausgegeben, bei dem err_type auf AP_SVC festgelegt ist, während in RECEIVE, PENDING_POST, CONFIRM, CONFIRM_SEND oder CONFIRM_DEALLOCATE Zustand. Die an den Partner-TP gesendeten Daten wurden möglicherweise gelöscht.
Bemerkungen
Die Unterhaltung muss sich im SEND-Zustand befinden, wenn das TP dieses Verb ausgibt. Statusänderungen werden basierend auf primary_rc in der folgenden Tabelle zusammengefasst.
primary_rc | Neuer Zustand |
---|---|
AP_OK | Keine Änderung |
AP_ALLOCATION_ERROR | ZURÜCKSETZEN |
AP_CONV_FAILURE_RETRY | ZURÜCKSETZEN |
AP_CONV_FAILURE_NO_RETRY | ZURÜCKSETZEN |
AP_DEALLOC_ABEND | ZURÜCKSETZEN |
AP_DEALLOC_ABEND_PROG | ZURÜCKSETZEN |
AP_DEALLOC_ABEND_SVC | ZURÜCKSETZEN |
AP_DEALLOC_ABEND_TIMER | ZURÜCKSETZEN |
AP_PROG_ERROR_PURGING | EMPFANGEN |
AP_SVC_ERROR_PURGING | EMPFANGEN |
SEND_DATA kann auf unbestimmte Zeit warten, da der Partner TP kein Empfangsverb ausgestellt hat. Wenn dies der Fall ist, kann der Sendepuffer ausgefüllt werden.
Die im Sendepuffer der lokalen LU gesammelten Daten werden an die Partner-LU (und partner TP) übertragen, wenn eine der folgenden Aktionen auftritt:
Der Sendepuffer wird ausgefüllt.
Die lokalen TP-Probleme "FLUSH", " CONFIRM" oder "DEALLOCATE " (oder ein anderes Verb, das den Sendepuffer der LU löscht).