C - > COBOL主机上的中介语沟通

时间:2016-11-02 22:30:48

标签: c cobol mainframe

在大型机上用C编写的供应商软件包提供了通过用户出口覆盖其部分功能的选项。提供的C函数原型是:

extern int SomeExit (void * Parameters,
                     void * Record1,
                     void * Record2,
                     char ComparisonType,
                     char * RankString,
                     void * NotUsed1,
                     int * NotUsed2)

由于我们主要是COBOL商店,因此我定义了一个Enterprise COBOL 4.2程序(作为DLL)来实现退出尝试遵循IBM ILC指南(https://www.ibm.com/support/knowledgecenter/en/SSLTBW_1.13.0/com.ibm.zos.r13.ceea400/clcccb5.htm#clcccb5)中给出的约定以及此旧示例SHARE演示文稿:http://www-01.ibm.com/support/docview.wss?uid=swg27003846&aid=1但是生成的程序在调用退出时和我的DISPLAY消息之前是异常终止的。我的假设是我没有正确声明接收数据结构。下面是我当前测试代码的片段(忽略我的命名约定 - 这是一个证明界面的原型,一旦我的基本调用工作就会被重写为我们的内部标准)。

IDENTIFICATION DIVISION.   
PROGRAM-ID.    "SomeExit". 
...
LINKAGE SECTION.                                               
01  WS-PARAMETERS-POINTER       USAGE IS POINTER SYNCHRONIZED. 
01  SORT-PASS-RECORD1-POINTER   USAGE IS POINTER SYNCHRONIZED. 
01  SORT-PASS-RECORD2-POINTER   USAGE IS POINTER SYNCHRONIZED. 
01  WS-COMPARISION-TYPE         PIC X.
01  WS-RANK-STRING-POINTER      USAGE IS POINTER SYNCHRONIZED. 
01  WS-NOT-USED1-POINTER        USAGE IS POINTER SYNCHRONIZED. 
01  WS-NOT-USED2-POINTER        USAGE IS POINTER SYNCHRONIZED. 
01  WS-RETURN                   PIC S9(9) USAGE IS BINARY.
...
PROCEDURE DIVISION USING BY VALUE WS-PARAMETERS-POINTER     
                     SORT-PASS-RECORD1-POINTER          
                     SORT-PASS-RECORD2-POINTER          
                     WS-COMPARISION-TYPE                
                     WS-RANK-STRING-POINTER             
                     WS-NOT-USED1-POINTER               
                     WS-NOT-USED2-POINTER               
               RETURNING WS-RETURN.                     

DISPLAY 'IN EXIT'.
... 
MOVE 0 TO WS-RETURN.
GOBACK.

异常终止是:

CEE3250C The system or user abend U 016 R=00000000 was issued.                                                     
     From entry point main at compile unit offset +00000192 at entry offset +00000192 at address 28500ECA.     

供应商代码动态调用DLL。当我删除DLL时,我收到一条消息,指出无法找到退出,因此看起来C代码正试图调用它。

我尝试了PROCEDURE DIVISION USING的变体,包括删除BY VALUE,使用BY REFERENCE(虽然我理解这是默认设置)并将POINTERs替换为实际结构定义。我是否误解了有关如何构造传递给COBOL例程的参数的手册?

编辑:我确实有一个与供应商打开的支持票,但他们还没有回复任何有用的东西。

谢谢大卫

1 个答案:

答案 0 :(得分:4)

感谢评论,我能够根据每个Bills建议更好地理解呼叫结构来确定解决方案。鉴于这个C原型:

extern int SomeExit (void * Parameters,
                     void * Record1,
                     void * Record2,
                     char ComparisonType,
                     char * RankString,
                     void * NotUsed1,
                     int * NotUsed2)

解决方案:

IDENTIFICATION DIVISION.     
PROGRAM-ID.    "SomeExit".   
...
LINKAGE SECTION.      
01  WS-PARAMETERS        PIC X(10).    
01  SORT-PASS-RECORD1    PIC X(50).    
01  SORT-PASS-RECORD2    PIC X(50).    
01  WS-COMPARISON-TYPE   PIC X.
01  WS-RANK-STRING       PIC X(6).                  
01  WS-NOT-USED1         PIC X.                     
01  WS-NOT-USED2         PIC X.                     
01  WS-RETURN            PIC S9(9) USAGE IS BINARY.
... 
PROCEDURE DIVISION USING                     
        BY REFERENCE WS-PARAMETERS       
        BY REFERENCE SORT-PASS-RECORD1   
        BY REFERENCE SORT-PASS-RECORD2   
        BY VALUE     WS-COMPARISON-TYPE  
        BY REFERENCE WS-RANK-STRING      
        BY REFERENCE WS-NOT-USED1        
        BY REFERENCE WS-NOT-USED2        
           RETURNING WS-RETURN.          
    DISPLAY 'IN EXIT'.
    ... 
    MOVE 0 TO WS-RETURN.
    GOBACK.

通过上述操作,成功调用了用户出口并将值返回给供应商逻辑。我使用以下参数进行编译RENT, TRUNC(BIN), DLL,EXPORTALL和链接DYNAM(DLL),RENT。我的应用程序不需要,但如果调用程序期望在上面的示例解决方案中使用的被调用程序中的混合大小写例程名称,那么也需要PGMNAME(LONGMIXED)

感谢所有评论者指出我正确的方向。