Dynamically calling the IBM MQ stub
Instead of link-editing the IBM MQ stub program with your object code, we can dynamically call the stub from within your program.
We can do this in the batch, IMS, and CICSĀ® environments. This facility is not supported in the RRS environment. If our application program uses RRS to coordinate updates, see RRS Considerations.
However, this method:- Increases the complexity of your programs
- Increases the storage required by your programs at execution time
- Reduces the performance of your programs
- Means that we cannot use the same programs in other environments
- For batch and IMS, in the STEPLIB concatenation of the JCL.
- For CICS, in the CICS DFHRPL concatenation.
For IMS, ensure that the library containing the dynamic stub (built as described in the information about installing the IMS adapter in Set up the IMS adapter ) is ahead of the data set SCSQLOAD in the STEPLIB concatenation of the region JCL.
Use the names shown in Table 1 when you call the stub dynamically. In PL/I, only declare the call names used in your program.MQI call | Batch (non-RRS) dynamic call names | CICS dynamic call names | IMS dynamic call names |
---|---|---|---|
MQBACK | CSQBBACK | not supported | Not supported |
MQBUFMH | CSQBBFMH | CSQCBFMH 1 | MQBUFMH |
MQCB | CSQBCB | CSQCCB 1 | Not supported |
MQCLOSE | CSQBCLOS | CSQCCLOS | MQCLOSE |
MQCMIT | CSQBCOMM | not supported | Not supported |
MQCONN | CSQBCONN | CSQCCONN | MQCONN |
MQCONNX | CSQBCONX | CSQCCONX | MQCONNX |
MQCRTMH | CSQBCTMH | CSQCCTMH 1 | MQCRTMH |
MQCTL | CSQBCTL | CSQCCTL 1 | Not supported |
MQDISC | CSQBDISC | CSQCDISC | MQDISC |
MQDLTMH | CSQBDTMH | CSQCDTMH 1 | MQDLTMH |
MQDLTMP | CSQBDTMP | CSQCDTMP 1 | MQDLTMP |
MQGET | CSQBGET | CSQCGET | MQGET |
MQINQ | CSQBINQ | CSQCINQ | MQINQ |
MQINQMP | CSQBIQMP | CSQCIQMP 1 | MQINQMP |
MQMHBUF | CSQBMHBF | CSQCMHBF 1 | MQMHBUF |
MQOPEN | CSQBOPEN | CSQCOPEN | MQOPEN |
MQPUT | CSQBPUT | CSQCPUT | MQPUT |
MQPUT1 | CSQBPUT1 | CSQCPUT1 | MQPUT1 |
MQSET | CSQBSET | CSQCSET | MQSET |
MQSETMP | CSQBSTMP | CSQCSTMP 1 | MQSETMP |
MQSTAT | CSQBSTAT | CSQCSTAT 1 | MQSTAT |
MQSUB | CSQBSUB | CSQCSUB 1 | MQSUB |
MQSUBRQ | CSQBSUBR | CSQCSUBR 1 | MQSUBRQ |
- Batch and COBOL: see Figure 1
- CICS and COBOL: see Figure 2
- IMS and COBOL: see Figure 3
- Batch and assembler: see Figure 4
- CICS and assembler: see Figure 5
- IMS and assembler: see Figure 6
- Batch and C: Figure 7
- CICS and C: see Figure 8
- IMS and C: see Figure 9
- Batch and PL/I: see Figure 10
- IMS and PL/I: see Figure 11
... WORKING-STORAGE SECTION. ... 05 WS-MQOPEN PIC X(8) VALUE 'CSQBOPEN'. ... PROCEDURE DIVISION. ... CALL WS-MQOPEN WS-HCONN MQOD WS-OPTIONS WS-HOBJ WS-COMPCODE WS-REASON. ...
... WORKING-STORAGE SECTION. ... 05 WS-MQOPEN PIC X(8) VALUE 'CSQCOPEN'. ... PROCEDURE DIVISION. ... CALL WS-MQOPEN WS-HCONN MQOD WS-OPTIONS WS-HOBJ WS-COMPCODE WS-REASON. ...
... WORKING-STORAGE SECTION. ... 05 WS-MQOPEN PIC X(8) VALUE 'MQOPEN'. ... PROCEDURE DIVISION. ... CALL WS-MQOPEN WS-HCONN MQOD WS-OPTIONS WS-HOBJ WS-COMPCODE WS-REASON. ... * ----------------------------------------------------------- * * * If the compilation option 'DYNAM' is specified * then you may code the MQ calls as follows * * ----------------------------------------------------------- * ... CALL 'MQOPEN' WS-HCONN MQOD WS-OPTIONS WS-HOBJ WS-COMPCODE WS-REASON. ...
... LOAD EP=CSQBOPEN ... CALL (15),(HCONN,MQOD,OPTIONS,HOBJ,COMPCODE,REASON),VL ... DELETE EP=CSQBOPEN ...
... EXEC CICS LOAD PROGRAM('CSQCOPEN') ENTRY(R15) ... CALL (15),(HCONN,MQOD,OPTIONS,HOBJ,COMPCODE,REASON),VL ... EXEC CICS RELEASE PROGRAM('CSQCOPEN') ...
... LOAD EP=MQOPEN ... CALL (15),(HCONN,MQOD,OPTIONS,HOBJ,COMPCODE,REASON),VL ... DELETE EP=MQOPEN ...
... typedef void CALL_ME(); #pragma linkage(CALL_ME, OS) ... main() { CALL_ME * csqbopen; ... csqbopen = (CALL_ME *) fetch("CSQBOPEN"); (*csqbopen)(Hconn,&ObjDesc,Options,&Hobj,&CompCode,&Reason); ...
... typedef void CALL_ME(); #pragma linkage(CALL_ME, OS) ... main() { CALL_ME * csqcopen; ... EXEC CICS LOAD PROGRAM("CSQCOPEN") ENTRY(csqcopen); (*csqcopen)(Hconn,&ObjDesc,Options,&Hobj,&CompCode,&Reason); ...
... typedef void CALL_ME(); #pragma linkage(CALL_ME, OS) ... main() { CALL_ME * mqopen; ... mqopen = (CALL_ME *) fetch("MQOPEN"); (*mqopen)(Hconn,&ObjDesc,Options,&Hobj,&CompCode,&Reason); ...
... DCL CSQBOPEN ENTRY EXT OPTIONS(ASSEMBLER INTER); ... FETCH CSQBOPEN; CALL CSQBOPEN(HQM, MQOD, OPTIONS, HOBJ, COMPCODE, REASON); RELEASE CSQBOPEN;
... DCL MQOPEN ENTRY EXT OPTIONS(ASSEMBLER INTER); ... FETCH MQOPEN; CALL MQOPEN(HQM, MQOD, OPTIONS, HOBJ, COMPCODE, REASON); RELEASE MQOPEN;