GET_TP_PROPERTIES 동사는 TP(트랜잭션 프로그램) 및 현재 트랜잭션의 특성을 반환합니다.
다음 구조에서는 GET_TP_PROPERTIES 동사에서 사용하는 동사 제어 블록에 대해 설명합니다.
문법
struct get_tp_properties {
unsigned short opcode;
unsigned char opext;
unsigned char reserv2;
unsigned short primary_rc;
unsigned long secondary_rc;
unsigned char tp_id[8];
unsigned char tp_name[64];
unsigned char lu_alias[8];
unsigned char luw_id[26];
unsigned char fqlu_name[17];
unsigned char reserve3[10];
unsigned char user_id[10];
unsigned char prot_luw_id[26];
unsigned char pwd[10];
};
구성원
opcode
제공된 매개 변수입니다. 동사 작업 코드 AP_GET_TP_PROPERTIES 지정합니다.
opext
제공된 매개 변수입니다. 동사 연산 확장을 지정합니다. AP_EXTD_VCB 비트가 설정되면 get_tp_properties 구조에 동기화 지점 지원에 사용되는 prot_luw_id 멤버가 포함됨을 나타냅니다. 그렇지 않으면 동사 제어 블록이 user_id 멤버 바로 후에 끝납니다.
reserv2
예약 필드입니다.
primary_rc
반환된 매개 변수입니다. 동사가 완료될 때 APPC에서 설정한 기본 반환 코드를 지정합니다. 유효한 반환 코드는 발급된 APPC 동사에 따라 달라집니다. 이 동사에 대한 유효한 오류 코드는 반환 코드를 참조하세요.
secondary_rc
반환된 매개 변수입니다. 동사가 완료될 때 APPC에서 설정한 보조 반환 코드를 지정합니다. 유효한 반환 코드는 발급된 APPC 동사에 따라 달라집니다. 이 동사에 대한 유효한 오류 코드는 반환 코드를 참조하세요.
tp_id
제공된 매개 변수입니다. 로컬 TP를 식별합니다. 이 매개 변수의 값은 호출하는 TP의 TP_STARTED 또는 호출된 TP의 RECEIVE_ALLOCATE 의해 반환되었습니다.
tp_name
반환된 매개 변수입니다. 동사를 발급한 TP의 TP 이름을 제공합니다. 이름은 EBCDIC 공백이 있는 오른쪽에 패딩된 64바이트 EBCDIC 문자열로 반환됩니다.
lu_alias
반환된 매개 변수입니다. 로컬 LU에 할당된 별칭 이름을 제공합니다. ASCII 공백이 있는 오른쪽에 패딩된 8바이트 ASCII 문자열로 반환됩니다.
luw_id
반환된 매개 변수입니다. TP가 참여하는 트랜잭션에 대해 보호되지 않는 논리 작업 단위 식별자를 제공합니다. 트랜잭션에 여러 TP를 포함할 수 있습니다. 트랜잭션을 시작하는 TP를 대신하여 할당된 이 식별자를 사용하면 트랜잭션을 구성하는 대화가 논리적으로 연결될 수 있습니다.
luw_id 다음 필드를 사용하여 luw_id_overlay 구조체로 나타낼 수 있습니다.
typedef struct luw_id_overlay { unsigned char fqla_name_len; unsigned char fqla_name[17]; nsigned char instance[6]; unsigned char sequence[2];} LUW_ID_OVERLAY;
luw_id.fqla_name_len
원래 TP의 LU에 대한 정규화된 LU 이름의 1 바이트 길이입니다.
luw_id.fqla_name
원래 TP에 대한 LU의 정규화된 이름입니다. 이름은 NETID, 마침표 및 LU 이름으로 구성된 17 바이트 EBCDIC 문자열로 반환됩니다. 이름의 길이가 17바이트 미만이면 인스턴스 및 시퀀스 번호가 즉시 수행됩니다. 이 때문에 luw_id_overlay 구조체의 필드를 사용하여 해당 값에 액세스해서는 안 됩니다. 호환성을 위해서만 제공됩니다.)
luw_id.instance
원래 TP에 대해 LU에서 고유하게 생성한 6 바이트 문자열입니다.
luw_id.sequence
작업 단위의 세그먼트를 나타내는 2 바이트 숫자입니다. 동기화 지점이 지원되지 않는 경우 항상 1로 설정됩니다.
luw_id 길이가 26바이트 미만이면 오른쪽에 EBCDIC 공백이 채워집니다.
fqlu_name
반환된 매개 변수입니다. 로컬 LU의 정규화된 이름을 제공합니다. 이름은 NETID, 마침표 및 LU 이름으로 구성된 17 바이트 EBCDIC 문자열로 반환됩니다. 이름은 오른쪽에 EBCDIC 공백으로 채워집니다.
reserve3
예약 필드입니다.
user_id
제공된 매개 변수입니다. 할당 요청에서 시작 TP에서 제공하는 user_id 나타냅니다. 이름은 EBCDIC 공백이 있는 오른쪽에 패딩된 10바이트 EBCDIC 문자열로 제공됩니다.
prot_luw_id
반환된 매개 변수입니다. 대화가 동기화 지점과 함께 할당된 경우 TP가 참여하는 트랜잭션에 대해 보호된 논리 작업 단위 식별자를 포함합니다.
트랜잭션에 여러 TP를 포함할 수 있습니다. 트랜잭션을 시작하는 TP를 대신하여 할당된 이 식별자를 사용하면 트랜잭션을 구성하는 대화가 논리적으로 연결될 수 있습니다.
prot_luw_id 다음 필드를 사용하여 luw_id_overlay 구조체로 나타낼 수 있습니다.
typedef struct luw_id_overlay { unsigned char fqla_name_len; unsigned char fqla_name[17]; nsigned char instance[6]; unsigned char sequence[2];} LUW_ID_OVERLAY;
luw_id.fqla_name_len
원래 TP의 LU에 대한 정규화된 LU 이름의 1 바이트 길이입니다.
luw_id.fqla_name
원래 TP에 대한 LU의 정규화된 이름입니다. 이름은 NETID, 마침표 및 LU 이름으로 구성된 17 바이트 EBCDIC 문자열로 반환됩니다. 이름의 길이가 17바이트 미만이면 인스턴스 및 시퀀스 번호가 즉시 수행됩니다. 이 때문에 luw_id_overlay 구조체의 필드를 사용하여 해당 값에 액세스해서는 안 됩니다. 호환성을 위해서만 제공됩니다).
luw_id.instance
원래 TP에 대해 LU에서 고유하게 생성한 6 바이트 문자열입니다.
luw_id.sequence
작업 단위의 세그먼트를 나타내는 2 바이트 숫자입니다. 동기화 지점이 지원되지 않는 경우 항상 1로 설정됩니다.
prot_luw_id 길이가 26바이트 미만이면 오른쪽에 EBCDIC 공백이 채워집니다.
pwd
제공된 매개 변수입니다. 할당 요청에서 시작 TP의 user_id 암호를 포함합니다. 암호는 EBCDIC 공백이 있는 오른쪽에 패딩된 10바이트 EBCDIC 문자열로 제공됩니다.
반환 코드
AP_OK
기본 반환 코드; 동사가 성공적으로 실행되었습니다.
AP_PARAMETER_CHECK
기본 반환 코드; 매개 변수 오류로 인해 동사가 실행되지 않았습니다.
AP_BAD_TP_ID
보조 반환 코드; tp_id 값이 APPC에서 할당한 TP 식별자와 일치하지 않습니다.
AP_COMM_SUBSYSTEM_ABENDED
기본 반환 코드; 는 다음 조건 중 하나를 나타냅니다.
이 대화에 사용된 노드에 ABEND가 발견되었습니다.
TP와 PU 2.1 노드 간의 연결이 끊어졌습니다(LAN 오류).
TP 컴퓨터의 SnaBase에서 ABEND가 발견되었습니다.
시스템 관리자는 오류 로그를 검사하여 ABEND의 이유를 확인해야 합니다.
AP_COMM_SUBSYSTEM_NOT_LOADED
기본 반환 코드; 동사를 처리하는 동안 필요한 구성 요소를 로드하거나 종료할 수 없습니다. 따라서 통신을 할 수 없습니다. 정정 작업은 시스템 관리자에게 문의하세요.AP_INVALID_VERB_SEGMENT
기본 반환 코드; VCB는 데이터 세그먼트의 끝을 넘어 확장되었습니다.AP_STACK_TOO_SMALL
기본 반환 코드; 애플리케이션의 스택 크기가 너무 작아서 동사를 실행할 수 없습니다. 애플리케이션의 스택 크기를 늘입니다.AP_TP_BUSY
기본 반환 코드; APPC가 동일한 TP에 대한 다른 호출을 처리하는 동안 로컬 TP가 APPC에 대한 호출을 실행했습니다. 로컬 TP에 여러 스레드가 있고 둘 이상의 스레드가 동일한 tp_id 사용하여 APPC 호출을 실행하는 경우에 발생할 수 있습니다.AP_UNEXPECTED_DOS_ERROR
기본 반환 코드; 운영 체제가 로컬 TP에서 APPC 호출을 처리하는 동안 APPC에 오류를 반환했습니다. 운영 체제 반환 코드는 secondary_rc 통해 반환됩니다. Intel 바이트 교환 순서로 표시됩니다. 문제가 지속되면 시스템 관리자에게 문의하세요.
비고
이 동사는 사양 대화가 아닌 TP와 관련이 있으므로 TP는 모든 상태에서 동사를 발급할 수 있습니다. 상태 변경은 없습니다.
luw_id 멤버에는 fqla_name_len(TP를 시작하는 LU의 정규화된 LU 이름 길이), fqla_name(TP를 시작하는 LU의 정규화된 이름), 인스턴스(TP를 시작하는 LU에서 고유하게 생성됨) 및 시퀀스(항상 1로 설정되고 작업 단위 세그먼트를 나타낸)에 대한 필드가 포함됩니다.