ims dc self study complete tutorial

Post on 16-Apr-2017

5.157 Views

Category:

Technology

5 Downloads

Preview:

Click to see full reader

TRANSCRIPT

IMS DC

IMS DC Slide: 1

Pre-Requisite: IMS DB knowledge

An Introduction

IMS DC Slide: 2

• IMS: Which is a Hierarchical DBMS, supplied by IBM & runs on Mainframe Computers. It has 2 main components:Data Base (DB) Processing Data Communication (DC) Processing.

Note: DL/I DOS/VS does not support Data Communication Component.

Interactive Programs

IMS DC Slide: 3

• Major Kinds of Online Programs that can be written:

– Inquiry Programs– Data Entry Programs– Maintenance Programs– Menu Programs

COMPARISON BETWEEN ONLINE AND BATCH PROGRAMS

IMS DC Slide: 4

BATCH ONLINE

Pre-Determined Scheduling Intervals

Arbitrary Scheduling by Users

Necessary creation of Input Files

Processing of Data as it occurs

Lack of Access to current Data Data up-to-date and current and available for Inquiry

Delay in Processing Erroneous Data

Immediate error correction

Databases cannot be shared with other updating programs

Database can be shared with other updating programs

Software Components of an IMS DC system

Data base & datasets

CommunicationControl

Editing Modules(MFS)

Queue ManagerQPOOL

Message Queue Overflowdatasets

VTAM Terminals

MVS addressSpace

VTAM

Non VTAMTerminals

MVS Address space

IMS / VS controlregion

Logging

DLI

MVS addressSpace

MPP region

MVS addressSpace

MPP region

MVS addressSpace

MPP region

MVS addressSpace

BMP region

Logging data sets

VTAM Terminals

IMS DC Slide: 5

IMS-DC OFFERS:

IMS DC Slide: 6

1. A way to improve customer and internal service by providingcurrent and consistent information

2. A way to interact with users with critical response times

3. A way to distribute processing function to different locations

4. A way to improve productivity for online applications

Features of IMS:

IMS DC Slide: 7

1. Manages IMS-DC Terminal Network

2. Routes Messages for various destinations

3. Scheduling of messages

4. Manages resources allocated to IMS

5. Provides restart, recovery facilities

6. Interacts with Databases for data retrieval and updation

ELEMENTS OF AN IMS-DC ONLINE SYSTEM

TERMINALS

MESSAGES

REGIONS

PROGRAMS

DATABASES

IMS CONTROL BLOCKS

IMS LOGS

IMS DC Slide: 8

IMS STANDS BETWEEN THE TERMINAL AND THE APPLICATION PROGRAM

TERMINAL

DATABASE

IMS

INPUTMESSAGE

OUTPUTMESSAGE

INPUTMESSAGE

OUTPUTMESSAGE

PROCESS

IMS DCPROGRAM

IMS DC Slide: 9

IMS DC

IMS DC Slide: 10

• DC handles information in the form of messages that flow between remote terminals and application programs.

• Programs & Databases that will run under the control of IMS must be defined in the IMS system definition.

• Two main Categories of Resources:Application Resources & Data communication Resources

• Types of IMS DC Application Programs:BMP: Batch Message Processing, Scheduled by System operatorMPP: Message Processing Program, scheduled by IMS

IMS DC Slide: 11

• IMS/VS forms a layer in between the Terminal and the IMS-DC programs, this helps in asynchronous mode of communication. This type of program is called Message Processing Programs(MPPs)

• Message - is a unit of Data that gets transmitted between a program and a Terminal

• Primary Inputs to and outputs from DC programs are messages.• For each Input message, DC program does predictable

processing against its databases and sends an output message that to User’s screen.

How IMS uses MVS regions

IMS DC Slide: 12

Regions in IMS.

IMS/VS CONTROL REGION

TERMINAL TERMINAL

LOG DATASETS

MPPREGION

MPPREGION

MPPREGIONBMP

REGION

DATABASE DATASETS

Control Region

IMS DC Slide: 13

– The main function of this region is that, all terminal, Database, and Logging Operations associated with IMS-DC programs are performed through this Region.

MPP Region

IMS DC Slide: 14

• MPP Region

– is where IMS schedules & executes Message Processing Programs.

– The Number of MPP Regions determines the number of MPPs that can be active at any one time.

– A program that occupies an MPP Region runs until it has processed all of the input messages that IMS has received for it. Then it ends, and the MPP region in which it was running is freed and made available for another Application Program.

Batch Message Program

IMS DC Slide: 15

• BMP (Batch Message Processing) Region

– A BMP program is much like MPP, except that the terminal response is not required for each input Message. The Database Processing and input message requires does not have to be done immediately.

– These are typically Batch Programs.– The main Advantage is, it can access Data Bases

that are allocated to the IMS Control Region, for use by MPPs at the same time.

Terminals & Security under IMS

IMS DC Slide: 16

• LTERM: For Application Functions, IMS uses logical terminal names rather than Physical names. Note: Within IMS, each LTERM name is associated with one and only one physical terminal. Ex: LDPAYR01

• LTERM names are limited to 8 chars• Master Terminal

Terminals & Security under IMS

IMS DC Slide: 17

• SMU Security Maintenance UtilityRACF Resource Allocation & Control Facility

• Transaction Security

• SIGN ON verification

• LTERM security

How IMS Manages Input messages

IMS DC Slide: 18

• Three kinds of IMS input messages:a. Transactionsb. Terminal to Terminal messagec. IMS commands

• IMS uses first 8 bytes of an input message to identify the message’s type.

• How IMS handles the three kinds of Input messages ??? • Input message Editing

Input Message Editing

IMS DC Slide: 19

• Two types of common Editing :

IMS basic edit: Remove communication control characters from input message and add them to output messages.

Message Format Service edit: Provides more extensive editing functions.

MFS builds the input message that the application program will receive. Part of building that message, it can insert the eight character transaction code at the beginning of the message.

How IMS supports an Application Program

IMS DC Slide: 20

After editing, IMS has to store the transaction temporarily.

Queue manager stores the transactions in the message queue, QPOOL.

If multiple transaction types are queued but too few dependent regions are available for all of them, IMS makes scheduling decisions.

IMS DC & CICS

IMS DC Slide: 21

• Many users are running an application, the IMS system funnels all of their messages through one program.

• CICS treats each user separately, it treats each terminal user separately.

• Many users are entering data of the same program, all the messages they enter are routed to same application program by IMS. IMS Keeps track of where each message came from and where each output message should go.

IMS DC Slide: 22

IMS-DC Processing

Programming Elements for IMS-DC Processing

– DL/I Calls for DC Operation– PCB mask for DC Operation– Message Handling.

DL/I calls for DC operations

IMS DC Slide: 23

• Basic unit of I/O for data communication DL/I call is segment• Most messages consist of just one segment occurrence, some

may contain multiple segments.• Message segments are not arranged hierarchically, they just

represent parts of a message.

•A Data Base Call

•CALL ‘CBLTDLI’ USING

DLI-GU

DB-PCB-MASK

RSEGMENT

INV-SSA.

•A Data communication Call

•CALL ‘CBLTDLI’ USING

DLI-GU

IO-PCB-MASK

RSEGMENT.

DL/I calls for DC Operation

IMS DC Slide: 24

• CALL ‘CBLTDLI’ USING DLI-GU IO-PCB-MASKINPUT-MESSAGE-SEG.

• First argument is the Function Code• GU: Issue a GU call to retrieve the first segment of an Input

Message. • GN is issued to retrieve the subsequent Messages. • ISRT call is issued for each segment, to send an Output

Message.

PCB Mask for DC operation

IMS DC Slide: 25

• A DC call must specify a Linkage Section PCB Mask, which is a special one that’s just for Message Processing. It’s called I/O PCB.

• To provide address to this PCB, the program must name its Linkage section mask definition on the ENTRY statement at the beginning of the Procedure Division.

• I/O PCB must be the first PCB listed on the ENTRY statement.• Format of a I/O PCB is different from a data base PCB’s format.

Cobol Code for an I/O PCB mask.

IMS DC Slide: 26

• 01 IO-PCB-MASK.05 IO-PCB-LOGICAL-TERMINAL PIC X(8).05 FILLER PIC X(2).05 IO-PCB-STATUS-CODE PIC X(2).05 IO-PCB-DATE PIC S9(7) COMP-305 IO-PCB-TIME PIC S9(6)V9 COMP-305 IO-PCB-MSG-SEGMENT-NUMBER PIC S9(5) COMP.05 IO-PCB-MOD-NAME PIC X(8).05 IO-PCB-USER-ID PIC X(8).

Message Handling

IMS DC Slide: 27

– When GU or GN calls been issued to retrieve an Input Message Segment, DL/I places the Message Segment data in the specified I/O Area.

– When ISRT call is issued to send an output Message Segment, DL/I gets the Data from the specified I/O Area.

Retrieving an Input Message

IMS DC Slide: 28

• Application Program issues either a Single ‘GU’ call or a ‘GU’ call followed by one or more ‘GN’ calls.

• To retrieve single segment input message, One ‘GU’ call need to be issued. When the Program gets ‘QC’ status code ( Instead of Blanks), it should be noted that there is No messages in the Queue.

• To retrieve Multiple segment input Messages, need to issue ‘GU’ call first to retrieve the first Segment. Then, to retrieve subsequent message segments for that Message, it issues ‘GN’ calls repeatedly until ‘QD’ status code is encountered.

Send an Output Message

IMS DC Slide: 29

• Issue ISRT calls that specify the I/O PCB.

• The Program issues a separate ISRT calls for each segment (for Multiple Segments) to be written.

• I/O Area to be build before you issue this call

Input Message I/O Area Format

IMS DC Slide: 30

ZZ

LL Data

•LL – Length of Entire Segment Usage: S9(3) Comp

•ZZ – IMS Reserved Data Usage: S9(3) Comp

• Input Message I/O Area Format

Output Message I/O Area Format

Z1

LL Data

•LL – Length of Entire Segment Usage: S9(3) Comp

•Z1 & Z2 – IMS Reserved Data Usage: X(2)

Z2

IMS DC Slide: 31

COBOL PROGRAM -

IDENTIFICATION DIVISION.PROGRAM-ID. PGM01.ENVIRONMENT DIVISION.DATA DIVISION.WORKING-STORAGE SECTION.01 SWITCHES.

05 END-OF-MESSAGES-SW PIC X VALUE 'N'.88 END-OF-MESSAGES VALUE 'Y'.

01 INPUT-MESSAGE-IO-AREA.05 IN-LL PIC S9(3) COMP.05 IN-ZZ PIC S9(3) COMP.05 IN-TRAN-CODE PIC X(8).05 IN-INVNO PIC X(6).

01 O-TEMP PIC X(2000).

01 OUTPUT-MESSAGE-IO-AREA.05 OP-LL PIC S9(3) COMP-3 VALUE +14C.05 OP-ZZ PIC S9(3) COMP-3 VALUE ZERO.05 OP-INVNO PIC X(6).05 OP-STAX PIC 9(4).

IMS DC Slide: 32

01 DLI-FUNCTIONS.05 DLI-GU PIC X(4) VALUE 'GU '.05 DLI-ISRT PIC X(4) VALUE 'ISRT'.

01 RECEIVABLE-SEGMENT.05 R-INVOICE-NUMBER PIC X(6).05 R-INVOICE-DATE PIC X(6).05 R-PO-NUMBER PIC X(6).05 R-STAX PIC 9(4).

01 INVOICE-NO-SSA.05 FILLER PIC X(9) VALUE 'RECEISEG('.05 FILLER PIC X(10) VALUE 'RECEINVN ='.05 INVOICE-NO-SSA-VALUE PIC X(6).05 FILLER PIC X VALUE ')'.

01 MFS-MOD-NAME PIC X(8) VALUE 'MFSO '.

IMS DC Slide: 33

LINKAGE SECTION.

01 IO-PCB-MASK.05 IO-PCB-LOGICAL-TERM PIC X(8).05 FILLER PIC X(2).05 IO-PCB-STATUS-CODE PIC X(2).05 IO-PCB-DATE PIC S9(7) COMP-3.05 IO-PCB-TIME PIC S9(6)V9 COMP-3.05 IO-PCB-MSG-SEQ-NUMBER PIC S9(5) COMP.05 IO-PCB-MOD-NAME PIC X(8).05 IO-PCB-USER-ID PIC X(8).

*01 CR-PCB-MASK.

05 CR-PCB-DBD-NAME PIC X(8).05 CR-PCB-SEGMENT-LEVEL PIC XX.05 CR-PCB-STATUS-CODE PIC XX.05 CR-PCB-PROC-OPTIONS PIC X(4).05 FILLER PIC S9(5) COMP.05 CR-PCB-SEGMENT-NAME PIC X(8).05 CR-PCB-KEY-LENGTH PIC S9(5) COMP.05 CR-PCB-NUMB-SENS-SEGS PIC S9(5) COMP.05 CR-PCB-KEY PIC X(22).

IMS DC Slide: 34

PROCEDURE DIVISION.ENTRY 'DLITCBL' USING IO-PCB-MASK CR-PCB-MASK.

PERFORM 100-PROCESS UNTIL END-OF-MESSAGES.GOBACK.

100-PROCESS.PERFORM 110-GET-INPUT-MESSAGE.IF NOT END-OF-MESSAGES

PERFORM 120-GET-INVOICE-DATAPERFORM 150-INSERT-OUTPUT-SEGMENT.

110-GET-INPUT-MESSAGE.CALL 'CBLTDLI' USING DLI-GU

IO-PCB-MASKINPUT-MESSAGE-IO-AREA.

IF IO-PCB-STATUS-CODE = 'QC'MOVE 'Y' TO END-OF-MESSAGES-SW.

IMS DC Slide: 35

120-GET-INVOICE-DATA.MOVE IN-INVNO TO INVOICE-NO-SSA-VALUE.CALL 'CBLTDLI' USING DLI-GU

CR-PCB-MASKRECEIVABLE-SEGMENTINVOICE-NO-SSA.

IF CR-PCB-STATUS-CODE NOT = SPACEMOVE '9999' TO OP-STAX

ELSEMOVE R-INVOICE-NUMBER TO OP-INVNOMOVE R-STAX TO OP-STAX.

150-INSERT-OUTPUT-SEGMENT.CALL 'CBLTDLI' USING DLI-ISRT

IO-PCB-MASKOUTPUT-MESSAGE-IO-AREAMFS-MOD-NAME.

IMS DC Slide: 36

Message Format Services

IMS DC Slide: 37

• What is MFS?• Control Blocks• Format Set

– MFS, is an IMS feature that lets you use Formatted Display Screens.

– MFS Modules reside in the IMS Control Region, and they are invoked between IMS Communication Control Module and its Queue Manager.

– MFS can reduce system resources an application uses

MFS Control Blocks

IMS DC Slide: 38

Terminal

Device InputFormat (DIF)

Device OutputFormat (DOF)

Mesg InputDescriptor(MID)

Mesg OutputDescriptor(MOD)

Application Program

Input Message

Sent by Terminal

Output Message

Sent by Program

Output MessageRecv by Terminal

Input MessageRecv by Program

• To process a Transaction, MFS uses 4 Control Blocks.

DIF & MID

IMS DC Slide: 39

– For an Input Message, MFS uses a block called a Device Input Format (DIF) to interpret data as it’s received from a Terminal.

– It uses second Block called Message Input Descriptor (MID), to determine how that input Data should be formatted for presentation to the Application Program.

IMS DC Slide: 40

– For an Output Message, MFS uses similar blocks, a Message Output Descriptor (MOD) is used to interpret Data Received from the Application Program.

– A Device Output Format (DOF), is used to determine how that Data should be formatted for Transmission to the Terminal.

Format Set

IMS DC Slide: 41

• MFS control statements– MFS control statements are often referred as Format Set.

• Format Set:– Defines the way screens to be used in application will look.– Defines format of input & output messages.– Specifies the relationship between data on the screen and

data in a message. • MFS Language Utility is used to Translate the Format Sets to

the Control Blocks.

• /Format <MOD name>

Format of an MFS Control Statement

IMS DC Slide: 42

• COLS • 1 - 8 Label• 10 - 14 Operation• 16 - 71 Operand• 72 Continuation Char

• Three Groups of MFS Statements:Device Format Control StatementsMessage descriptor control statementsCompilation Control Statements

Define a Screen in Format Set

IMS DC Slide: 43

• One set of Control statements for both - for a 3270 same screen format must be used for both input & Output

• One Set of Control statements for both DIF & DOF• Device Format begins with FMT & ends with FMTEND• FMT

DEVDIV

DPAGEDFLDDFLD

DPAGEFMTEND

FMT

IMS DC Slide: 44

• FMT: Identifies the beginning of a device format• FMTEND: Control statements end with a FMTEND statement• No parameters• Appropriate Label on FMT• Label coded on FMT statement can be no more than six

characters long.

Format Set

IMS DC Slide: 45

INQDF FMTDEV TYPE=(3270,2),FEAT=IGNORE,DSCA=X’OOAO’DIV TYPE=INOUTDPAGE CURSOR=((1,2))

TRANINV DFLD POS=(1,2),LTH=15OUTTEXT DFLD POS=(3,2),LTH=702

FMTENDINQO MSG TYPE=OUTPUT,SOR=(INQDF,IGNORE),NXT=INQI

SEGMFLD OUTTEXT,LTH=702MSGEND

INQI MSG TYPE=INPUT,SOR=(INQDF,IGNORE),NXT=INQOSEGMFLD TRANINV,LTH=15MSGENDEND

DEV Control Statement

IMS DC Slide: 46

• PFKDF FMTDEV TYPE=(3270,1)

FEAT = IGNOREPFK=(PFKTEXT,1=‘01’,2=‘02’,8=‘08’)

FMTEND

PFKEXI MSG TYPE=INPUT,SOR=(PFKDF,IGNORE),NXT=PFKDFO

SEGMFLD PFKTEXT,

LTH=2MSGEND

DEV

IMS DC Slide: 47

• TYPE: Specify the device models for which device format blocks should be created.

• DSCA: To specify a default terminal action that’s performed when an output message is sent to a 3270 device.Ex: DSCA=X’00A0’ causes unprotected fields on the screen to be erased before the output message is displayed.

• SYSMSG: Names a device field in which messages that come to the terminal from IMS will be displayed.

• DPAGE: Primary Function Handle Multiple logical pages Secondary Function: Initial Cursor positioning & Field Fill

Program Function Keys (PFKeys)

IMS DC Slide: 48

• PFK parameter specifies how MFS should support program function keys.

• First Part: Target input message field• Second Part: Keyword / positional format

• Positional:PFK=(PFKTEXT,‘01’,‘02’,,,,,,‘08’)

DEV TYPE= (3270,1)(3270,2)3270-An

,FEAT=IGNORE[,PFK=(pfkeyfield,[integer=] ‘literal’

NEXTPPNEXTMSGP [,…])]ENDMPP1

IMS DC Slide: 49

DPAGE

IMS DC Slide: 50

• Label DPAGE [CURSOR=(LINE,COL,CFIELD)…][FILL=fillchar][MULT=Yes]

• FILL: The fill character to be used for output device fields.Ex: PT, C’c’, X’hh’

• MULT: Multiple physical pages within device page can be used to generate an input message.

DFLD

IMS DC Slide: 51

• Specifies where on the screen a field is located & how large thefield is.

• Need to code a label only when the device field it defines are to be related with a input, output or both.

• LTH : Not to be coded for a Literal in a device field • DFLD ‘ABC Company Services’,

POS=(1,2),ATTR=(HI,PROT)

• CURDATE DFLD POS=(1,72),LTH=8ATTR=(HI,PROT)

DFLD Statement

IMS DC Slide: 52

• ATTR: Field Characteristics• Default Protection attribute for a non-literal field is unprotected• Label DFLD ‘literal’,

POS=(1,1),LTH=20,ATTR=ALPHA

• ATTR=• ALPHA / NUM• NOPROT/PROT• NORM/NODISP/HI• NOMOD/MOD

Modified Data Tags

IMS DC Slide: 53

• MDT tag indicates whether or not the data in the field has been changed by the terminal user since the screen was sent to the device.

• When a screen is displayed, MDT’s of fields is OFF.• Advantage: Telecommunications Efficiency

Define Messages in a Format Set

IMS DC Slide: 54

• Code separate sets of control statements to define a MID and a MOD.

• Begin with a MSG & end with a MSGEND.• MOD: TYPE=OUTPUT• MID: TYPE=INPUT• Must code a label on the MSG statement.• Message Fields: MFLD• LTH=55 (LL & ZZ fields that are defined in the segment I/O

areas need not be included in the message description in the format set.

Message Descriptor Control Statements

IMS DC Slide: 55

• MSGLPAGE

PASSWORDMFLD

SEGMFLDMFLD

LPAGESEG

MFLDMSGEND

MSG

IMS DC Slide: 56

• msgname MSG TYPE=(INPUT / OUTPUT ) SOR =(dfname,IGNORE)NXT=nextmsgnamePAGE=YES

MSGEND• SOR: Parameter on each MSG statement. Code the name of the

device format (FMT statement label) that is associated with the message this group of statements define.

• NXT: Parameter specifies the message descriptor MFS that will be used. MSG that defines a MID you code a MOD and for MOD you code the MID label.

MFLD Control Statement

IMS DC Slide: 57

• MFLD {SOURCE / DESTINATION }LTH = LengthJUST={L / R}FILL=fillcharATTR=(YES)

• Input Message Field Descriptor:-MFLD ‘DI2 ‘, LTH=8MFLD INVNO,LTH=6MFLD (INVNO,’000000’),LTH=6• Output Message field:-

MFLD (CURDATE,DATE2)

JUST, FILL, ATTR parameter in MFLD Statement

IMS DC Slide: 58

• JUST parameter specifies how data should be positioned in a message field.

• Default is Left Justification

• FILL parameter specifies what pad character MFS should use to complete a field when the data that’s mapped into it doesn’t fill. you with Ex: FILL=C’0’

FILL=X’ ‘FILL=NULL

• ATTR = YES specifies that an application program can dynamically change the attributes set in the Device field.

Compilation Control Statements

IMS DC Slide: 59

• PRINT ON,NOGEN• PRINT OFF• END• EJECT• COPY • symbol EQU ‘literal’

APA EQU ‘ATTR=(PROT,ALPHA)’SUBTOTAL DFLD POS=(3,55),LTH=9,APA

IMS DC Slide: 60

• By default : Same MOD to be used for an output message that was used for the previous entry.

• Complex Screen Flows: • When output formats are changed, when 2 or more screen

displays are used.

IMS DC Slide: 61

• Format of the ISRT call with the MOD name segmentCALL ‘CBLTDLI’ USING DLI-ISRT

IO-PCB-MASKOUTPUT-MESSAGE-IO-AREAMFS-MOD-NAME.

MFS-MOD-NAME is a working storage field defined with PIC X(8).

• How to Control screen flows from within MFS ?Easy to control screen flows from within an application without involving application program. Provide a way for the operator tocause an input message that begins with:/format mod-name

Screen Example

IMS DC Slide: 62

• Receivables Menu Date: xxxxxxx

PF1 Enter Cash ReceiptsPF2 Display Invoice Summary

Format Set for Menu Program

IMS DC Slide: 63

• MENUDF FMTDEV TYPE=(3270,2),FEAT=IGNORE,SYSMSG=ERRMSG,

PFK=(PFKFIELD,’/FOR CRO ‘,’/FOR DI2O ‘,’/FOR DIDSO’)DIV TYPE=INPUTDFLD ‘Receivables Menu’,POS=(1,2),ATTR=(PROT,ALPHA,HI,NOMOD)DFLD ‘Date’,POS=(1,65),ATTR=(PROT,ALPHA,HI,NOMOD)

CURDATE DFLD POS=(1,72),LTH=9,ATTR=(PROT,ALPHA,HI,NOMOD)…………………………………...

ERRMSG DFLD POS(23,2),LTH=79,ATTR=(PROT,ALPHA,NORM,NOMOD)FMTEND

MENUI MSG TYPE=INPUT,SOR=(MENUDF,IGNORE),NXT=MENUOSEGMFLD PFKFIELD,LTH=10MSGEND

MENUO MSG TYPE=OUT,SOR=(MENUDF,IGNORE),NXT=MENUISEGMFLD (CURDATE,DATE2)MFLD LTH=1MSGEND

IMS DC Slide: 64

• Field attributes values set with ATTR parameter of DFLD statement and CURSOR parameter of the DPAGE statement could be dynamically changed.

• Used to call attention to data entry errors.• Steps:-• Identify fields that are eligible for dynamic field attribute

modifications by setting ATTR = YES in MFLD statement.

Identifying the Output Message Fields

IMS DC Slide: 65

• Steps:-• Identify fields that are eligible for dynamic field attribute

modifications by setting ATTR = YES in MFLD statement.• 2 bytes of MFLD will contain control information that specifies

what the overriding attributes will be.• Increase the LTH of the Message Field by 2.• MFLD INVNO,LTH=8,ATTR=YES• Two bytes prefix is packed with information.• First byte is cursor control. If cursor positioning is not required

all the bits in the first control byte should be 0000 0000. (LowValues)

Specify Field Attributes overrides from a Program

IMS DC Slide: 66

05 OM-INVOICE-NO.10 OM-INVOICE-NO-PREFIX.

15 OM-INVOICE-NO-CURSOR PIC X VALUE LOW-VALUE.15 OM-INVOICE-NO-ATTR PIC X.

10 OM-INVOICE-NO-DATA PIC X(6).

• Ex: A common function is changing fields intensity from normal to bright without changing other attributes. 1000 0000 is required in second byte.

• 05 ATTR-CHANGE-TO-BRIGHT PIC X VALUE ‘h’.• Setting a fields default attribute: 1000 0000, hex 80

05 ATTR-RESET-TO-DEFAULT PIC X VALUE ‘ ‘.• To mark a field with error,

MOVE ATTR-CHANGE-TO-BRIGHT TO OM-INVOICE-NO-ATTR

Cursor & Attribute ControlFirst byte (Cursor Control) Second Byte (Attribute Control)

0 0 0 0 0 0 1 0Bit 0 1 2 3 4 5 6 7 0 1 2 3 4 5 6 7

CursorPositioning

Shift Intensity Pen MDT

ProtectionAttribute Override

Byte

Bits Function Values

1 0-1 Cursor Pos. 00 Cursor Positioning not requested11 Position cursor at this field. (Values 01 and 10 are invalid)

2-7 000000 (Always)2 0 1 (Always)

1 AttributeOverride Type

0 Use the attr. Specifications that follow to activate only specifiedattributes (that is attributes whose corresponding override bit is on

1 Use the attribute specs that follow to replace all device field attribu2 Protect. Attr. 0 Unprotected

1 Protected3 Shift Attribute 0 Alphanumeric Shift

1 Numeric Shift4-5 Intensity Attrib 00 Normal Intensity

01 No-display10 Bright Intensity11 Bright Intensity

6 Light-pen Attr 0 Should be 0 for non- Light – Pen applications7 MDT 0 MDT off

1 MDT on

IMS DC Slide: 67

Control the cursor

IMS DC Slide: 68

• Two type we can position the cursor from an application Program:Field Oriented Cursor control Absolute Cursor Control

• Field Oriented CursorTo require cursor positioning at a field, move the left brace hex value, hex C0, binary 1100 0000 to the first of the two control bytes. Don’t want Cursor positioning at a field, first byte of the prefix should contain Low-Value.

Absolute Cursor Control

IMS DC Slide: 69

• Program specifies the exact column & line position where the cursor will be located.

• CURSOR parameter of DPAGE statement:CURSOR=(line,column,cfield)

MFLD CFIELD,LTH=4• 05 IM-CURSOR-LOCATION.

10 IM-CURSOR-LINE PIC S9(3) COMP.10 IM-CURSOR-COLUMN PIC S9(3) COMP.

IMS DC Slide: 70

• Paging: Is a facility that lets message be broken down into components for display, for processing or for both.

• Physical Paging / Logical Paging• Physical Paging: A message with a fixed number of segments is

further divided into parts that are sized properly for a particular device.

• Implement physical paging through the DFLD statement.Ex: POS=(8,12,3)

IMS DC Slide: 71

FIELD3 DFLD POS=(3,12) FIELD3 DFLD POS=(3,12)FIELD4 DFLD POS=(4,12) FIELD4 DFLD POS=(4,12)…………………………… ……………………..FIELD14 DFLD POS=(14,12) FIELD14 DFLD POS=(3,12,2)FIELD15 DFLD POS=(15,12) FIELD15 DFLD POS=(3,12,2)FIELD16 DFLD POS=(16,12) FIELD16 DFLD POS=(3,12,2)FIELD17 DFLD POS=(17,12) FIELD17 DFLD POS=(3,12,2)FIELD18 DFLD POS=(18,12) FIELD18 DFLD POS=(3,12,2)

• Operator Physical Paging: Program Function keys could be used.

• PFK=(PFKIN,08=NEXTPP,10=NEXTMSGP)

Multiple Physical Page Input

IMS DC Slide: 72

• MFS provides a facility to generate a single physical input message from multiple physical pages.DPAGE StmtMULT=YES

• Operations:• Operator presses ENTER key for each Screen• PF1 to skip over the screen without making an entry• Operator can use a PF key associated with MFS operator

command ENDMPPI to signal to MFS that multiple physical page input is over and complete input message can be constructed.

• CURSOR=((3,12),(3,12)),MULT=YESS

Logical Paging

IMS DC Slide: 73

• A logical page is usually associated with a single screen image.• With logical paging, we can send multiple occurrences of the

same screen, but with different data, as part of one output message.

• Logical paging is often used for applications that produce relatively large amounts of output.

• A group of related fields either on the screen or in a message is called a Logical page.

• Logical Page implemneted by LPAGE & DPAGE• DPAGE: Device Page, 1 - 8 char label to link to Lpage• LPAGE: Message Page

Operator Logical Paging Commands

IMS DC Slide: 74

• Command Action• = Move Forward one logical page• =nnn Move to logical page nnn• =l Move to last logical page• =-nnn Move backward nnn logical pages• =+nnn Move forward nnn logical pages

• For the operator to use the logical paging commands, a device field should be present into which he can enter paging commands.

How to define message pages

IMS DC Slide: 75

• LPAGE, no other function other than logical pages• Codes only in format sets that don’t use logical paging• LPAGE - DPAGE relationship:

– SUMLPAGE LPAGE SOR=SUMDPAGE,….• How does MFS know which LPAGE to select?• Program has to move an identifying value to a particular field

in the output message segment.SUMLPAGE LPAGE SOR=SUMDPAGE,

COND=(LPAGEID=,’S’)SEG

LPAGEID MFLD LTH=1

How to support operator logical paging

IMS DC Slide: 76

• Enable Operator logical pagingPAGE = YES (on the MOD)

• The above statement tells MFS to examine a related input message to see if they begin with an operator logical paging command.

PAGECMD DFLD POS(22,17),LTH=5,ATTR(NOPROT,ALPHA,NORM,NOMOD)

SEGMFLD PAGECMD,LTH=5,

IMS DC Slide: 77

• Alternate Destination Concepts :– The application Program that’s processing a

Single Input Message can send multiple Output Message to Multiple Destinations.

– ISRT call is issued but only difference is that the call specifies Alternate PCB instead of I/O PCB.

IMS DC Slide: 78

– Alternate PCB (ALTPCB), which are specified in the programs PSBGEN job, name the other terminals or transactions to which the program can send Messages.

ApplicationProgram

DataBase

Terminal

Printer

Input Message

Output Message(IOPCB)

Output Message

(ALTPCB)

IMS DC Slide: 79

• Conversational Application– There are three ways to maintain Data

between Terminal Interaction.• Store Data in the Terminal Screen.• Store Data in the Databases• Store Data in the IMS provided Scratch Pad

Area.

IMS DC Slide: 80

• Advantages & Disadvantages of these Techniques.– The First technique, is suitable only if the

Data is Simple & Non-Critical. – The Second Technique, makes your Program

more complicated and less efficient.– The Last Technique, is to use a special area

IMS provides just for that Purpose : The Scratch Pad Area (SPA).

IMS DC Slide: 81

• Scratch Pad Area (SPA)– A conversational Program must use a SPA.– A Unique SPA is associated with each

terminal that’s running a conversational transaction.

IMS DC Slide: 82

• Using SPA:– Define I/O Area for SPA :

01 SPA-IO-AREA.05 SPA-LL PIC S9(4) COMP.05 SPA-ZZ PIC S9(4) COMP.05 SPA-CI PIC S9(4) COMP.05 SPA-TRAN-CODE PIC X(8).05 SPA-USER-DATA PIC X(---).

– The area is much similar to the Message Segment– In Addition to LL & ZZ fields, the SPA contains a Third

binary halfword CI (Conversational Identifier) which IMSuses to keep track of SPA.

IMS DC Slide: 83

• IMS Calls in Conversational Programs :– In Conversational Programs, SPA should be

retrieved first before retrieving Message Segments. This is done by issuing a ‘GU’ call against I/O PCB.

CALL ‘CBLTDLI’ USING DLI-GUIO-PCB-MASKSPA-IO-AREA.

IMS DC Slide: 84

– To save Data in the SPA, an ISRT call is issued against I/O PCB.

CALL ‘CBLTDLI’ USING DLI-ISRTIO-PCB-MASKSPA-IO-AREA

– You must not send an output Message Segment before you have saved the SPA.

– At the start of conversation, the SPA is set to Binary Zeros.

IMS DC Slide: 85

• Program Switching :– Switching from on Conversational Program to

Another requires that both the SPA & Message to be processed by the second program be transferred.

– There are two kinds of Program-to-Program Message switches

• Immediate Program Switching.• Deferred Program Switching.

• Immediate Program Switching :

Application Program - 1

Application Program - 2

Terminal

Output Message

Input Message

SPA

Switch Message Segment

IMS DC Slide: 86

IMS DC Slide: 87

– The Program that receives the input Message is not the same one that responds to the Terminal.

– The First Program passes in SPA and other necessary data to the second Program, which does additional processing and respond to the originating terminal.

• Deferred Program Switching :

Application Program - 1

Application Program - 2

Terminal

Output Message 2

Input Message 1

SPAOutput Message 1

Input Message 2

IMS DC Slide: 88

IMS DC Slide: 89

– A single Conversation involves two different Application Programs, one for each of two terminal Interactions.

– The data stored in SPA is passed from the first program to the Second.

– The second program isn’t invoked until the user sends the next input message

– This technique can impose less overhead on the IMS system & can result in faster response.

IMS DC Slide: 90

• Logging:– Records all Database Updates, all Message

queued and all program scheduled.– These Information can be used to restore the

system if a failure occurs.

IMS DC Slide: 91

– MTO (Master Terminal Operator) can manage other terminals in the network, as well as messages & programs execution in dependant Regions.

– The system maintains mtologs where the necessary details are stored when the abend occurs.

IMS DC Slide: 92

• Recovery:– IMS provides extensive facilities for

Recoveries in the event of failure– If an Application Program Abends, IMS

automatically reverse or Rollback the changes it has made to the Databases and Message Queues.

IMS DC Slide: 93

• Checkpointing:– The checkpoints are taken automatically with each

transaction a program processes. (This is called Single Mode Processing.)

– In Multiple Mode Processing, the only automatic checkpoint is at the End of the Program. However, the program can force a checkpoint by issuing CHKP call, which causes IMS to write a Checkpoint Record to the Log.

– The Checkpoint Call Syntax:

CALL ‘CBLTDLI’ USING DLI-CHKPIO-PCB-MASKINPUT-MESG-IO-AREA.

Thank You

IMS DC Slide: 94

top related