In general, the present invention relates to the emulation of functions from a source computer architecture to produce instructions that run on a target machine architecture. More particularly, the present invention is directed to the emulation of portions of a data processing system other than the CPU (Central Processing Unit) architecture. Even more particularly, the present invention is directed to the emulation of I/O (input/output) processors.
Emulation technology is becoming more prevalent in the industry due to the rising cost of hardware development, especially on high end systems. The resurgence of the mainframe class of machine has created an increased desire for code developers to write applications for this type of machine. One of the most significant ones of the high end systems is the zSeries™ of data processor manufactured and marketed by the assignee of the present invention. However, the cost factor for these high end systems is discouraging program writers and designers from working in this area, especially for development and for training purposes. Several vendors now provide zSeries™ processor emulations that run on either a UnixWare or Linux based workstation. However, included with the processor emulation is the increasing desire to emulate other parts of the system including DASD, coupling, I/O, and networking functions. Queued Direct I/O was introduced in 1990. It is a state-of-the-art I/O architecture which provides fast host to LAN communication. With the emulator of the present invention, several changes have been made to enhance the architecture and to improve Queued Direct I/O (QDIO) function on Linux and AIX® platforms. It is also noted that while the present invention focuses upon the Open System Adapter (OSA) as an emulation target, the principle methods and structures of the present invention are equally applicable to other adapters, an adapter simply being a piece of hardware used by a CPU, server, data processor, mainframe or the like for external communications.
In accordance with an aspect of the present invention, there is provided a computer program product for implementing data transfer protocols which emulate an Open System Adapter. The computer program product includes, for instance, a storage medium readable by a processor and storing instructions for execution by the processor for performing a method. The method includes, for instance, establishing a connection between a first portion of a host system memory, allocated for input/output operations, and a second portion of said host system memory, allocated as a buffer for data transfer operations based on a data transfer protocol that emulates the Open System Adapter; initializing parameters used for directing and structuring data transfer between the first portion and the second portion; based on the initializing, sending a data transfer related command to a first process; sending a command from said first process to an Open System Adapter emulation process; and transferring data, via a memory copy operation, between the first portion and the second portion in accordance with the parameters and at least one of the data transfer related command and the command.
Two designs are presented both of which are intended to implement emulation of OSA in this environment: a solution that contains a traditional I/O-processor-like system structure and a streamed down structure, titled the “device manager” (DM) structure.
A software structure is presented that provides an exact I/O zSeries™ representation for OSA. The focus of the design is to port the current zSeries OSA functions, keeping the existing infrastructure so that future enhancements and additions of other OSA adapter types are also possible.
The OSA function runs as single UNIX process in both the AIX® and INTEL® Linux environments. The OSA function works in conjunction with an IOP process that emulates an OSA Chpid (Channel Path ID). Along with the emulated OSA there is provided a LAN adapter on the AIX® platform that provides hardware assists presently available on the zSeries™ mainframe. For the present implementation, each OSA Chpid (that is, each OSA process+IOP process) is dedicated to a single LAN adapter provided by the workstation that runs the emulator software. The emulated OSA runs on Linux Commercial SuSE 10.x and on AIX® 5.3 or above. It will run on a Power based workstation and Intel based workstations. Additional features and advantages are realized through the techniques of the present invention. Other embodiments and aspects of the invention are described in detail herein and are considered a part of the claimed invention.
The recitation herein of a list of desirable objects which are met by various embodiments of the present invention is not meant to imply or suggest that any or all of these objects are present as essential features, either individually or collectively, in the most general embodiment of the present invention or in any of its more specific embodiments.
The subject matter which is regarded as the invention is particularly pointed out and distinctly claimed in the concluding portion of the specification. The invention, however, both as to organization and method of practice, together with the further objects and advantages thereof, may best be understood by reference to the following description taken in connection with the accompanying drawings in which:
The IOPLite process communicates to the OSA process via a vector referred to herein as SIGUSR2. In the discussions herein, the IOPLite to OSA CCA signal is referred to as the SIGUSR2 vector. It is issued to/from IOPLite to indicate that work is present (that is that data is ready to be sent or received). The CCA location is mapped into HSA (Host System Area) space for OSA in accordance with the specified Chpid number. OSA process 140 provides a read/write CCA function that is linked into the IOPLite process. Note that presently, the number of words to read or write is set to 2.
The format of the CCA invocation is as follows:
The following tables indicate basic lock value information. These lock values are checked for lock use before a write operation; typically they are checked to see whether or not they contain non-zero values.
The following table illustrates control information used by the control program to check busy status.
The following table describes the various return codes provided and their meanings
Behavior:
By using the combination of locks and Interrupt Vector (IV) bits shown above, the performance closely matches that which is achieved in hardware alone. The process works as follows:
Initialization Flow A 256 bit entry Chpid Directory is created in shared memory in the HSA location. All Chpids register the following information upon Chpid initialization:
Prior to the creation of the Chpid process, the IOCDS is parsed 200 (
Once the IOCDS is parsed and all the HSA Control Blocks for all Chpids have been built, the individual Chpid processes is created. One “parent” process 220 is created for each defined Chpid. From the Parent Chpid Process, the OSA 140 and IOPLite processes 130 are created as CHILD processes to the main Chpid process. This design helps in the error recovery scenarios. A “heartbeat” message is used between the Parent Chpid process and the IOP and OSA process to detect “hang” conditions. If an “abend” occurs, a Signal (SIGCHILD) is sent to the Parent Chpid process to signal the “abend”. This signal is used by the Parent to “logout” the information for the OSA or IOPLite process.
The parameter passed to the Chpid process at creation time is the Chpid Number. All other OSA shared memory names are derived from the chpid number. The I/O recovery process and I/O Chpid process are identified by a lookup in the shared Chpid Directory shown below in Table VII.
The OSA Config Name points to a file on a hard drive where all of the OSA parameters are kept that need to be saved across resets, such as MAC address, trace mask, etc. Allocation to Shared Memory locations causes a Registry entry to be created. The “Interface Number” is only used for OSA purposes. Interface names in ASCII have an “0x00” termination (for example, “np4 m0,” “np4 m1,” etc. for the Escon Card or “ent0,” “ent1,” etc. termination for OSA processes). If both the CHPID_STATE_NP_CARD bit and the CHPID_STATE_OSA_CARD bit are 0, the chpid is neither NP nor OSA.
Sharing Memory Blocks Per OSA Process: A shared storage segment is allocated for each z/Emulator process. This allows access to the data from external processes (CEC dump, manop (manual operations), system event, etc.). The shared Memory Managed by CP Functions and needed by OSA Chpids are listed in the table below:
The Signal Use for IOPLite systems is provided in the table below:
Logout Structure (See
Attention is now directed to a description of the flow of how an operator command is processed. When the operator issues a command, a command initiator is started. The command initiator passes a command and the operator arguments to a target process through the EmulatorCmd interface and waits for the command to complete. A return code indicates the status of the operation. The target process polls occasionally to determine if there are any outstanding operator commands to be processed. It is up to the target process to provide support for that command. API functions return the data and return code to the initiator process. A more detailed flow description follows.
The command initiator executes the emulatorCmd function passing componentName as arg[0], subCompName as arg[1], the actual command to be executed (arg2), and command parameters as arg3 through argX. The componentName and subCompName fields are used to locate the process in the shared resource registry. The emulatorCmd function sends the command and parameters to the specified component and subcomponent using the sendCmdV. The SendCmdV function then sends a SIGALRM signal to the receiving process to ensure that the process exits any wait loop to run its command polling routine. The emulatorCmd function waits on the response data and return code. If a predetermined time passes and no data or return code is received, an error code is returned and command processing terminates. In the application's normal processing loop, the application invokes procCmd, passing the name of a function to handle any commands received via the emulator command interface. procCmd determines if a command has been received and invokes the passed command processing routine. The command to be executed is passed as arg0 and its parameters as arg1 through argX. The application command processing routine returns any data via a call to sendCmdResp using printf formatted parameters. At command completion, procCmd returns the return code from the command processing routine to the command initiator and this return code is the final return code. Back on the command initiation side, the command responses are retrieved via the recvCmdResp function and command and EmulatorCmd direct this output to stdout. The return code is retrieved via the recvCmd function.
In
After ECB Main finishes, the actions in the block labeled Networking Main are initiated. These include reading the Chpid Registry to find OSA cards and defined states. The OSA recovery process is started. Networking Main 420 is a parent to the OSA Process and the related IOPLite process. This process (430) provides all OSA recovery functions including a watchdog timer.
In the OSA recovery process (430) Chpid Registry Information is filled out and IOPLite process 440 is begun. After the IOPLite initialization process 450, the IOPLite process sends the first CCA to OSA process 140 when the IOPLite process sees a ready bit. The details of the CCA are provided by IOP.
The OSA process (block 460) fills out Chpid specific Chpid Registry information and starts the process shown in block 470. This process includes the allocation of buffers and the initialization of trace, log and memory areas (See also
The process then waits for the data (step 480) and as long as there is no error (step 490) the process returns to a “waiting for data” state (step 480). If there is an error a Chpid/System x-stop is issued (step 495).
While the invention has been described in detail herein in accordance with certain preferred embodiments thereof, many modifications and changes therein may be effected by those skilled in the art. Accordingly, it is intended by the appended claims to cover all such modifications and changes as fall within the true spirit and scope of the invention.
This application is a continuation of co-pending U.S. Ser. No. 12/355,903, entitled “INPUT/OUTPUT PROCESSOR (IOP) BASED ZSERIES EMULATION,” filed Jan. 19, 2009 (U.S. Publication No. 2010/0185898, published Jul. 22, 2010, which is hereby incorporated herein by reference in its entirety.
Number | Name | Date | Kind |
---|---|---|---|
5652914 | Eckert et al. | Jul 1997 | A |
20030037178 | Vessey et al. | Feb 2003 | A1 |
20030093649 | Hilton | May 2003 | A1 |
20050268071 | Blandy et al. | Dec 2005 | A1 |
20050289246 | Easton et al. | Dec 2005 | A1 |
20100185898 | Chan et al. | Jul 2010 | A1 |
Entry |
---|
Office Action for U.S. Appl. No. 12/355,903 dated Dec. 27, 2011. |
Baskey et al., “zSeries Features for Optimized Sockets-Based Messaging: HiperSockets and OSA-Express”, IBM J. Res. & Dev. vol. 46, No. 4/5, Jul./Sep. 2002. |
Amrehn et al., “Linux on IMB zSeries and S/390: High Availability for z/VM and Linux”, Redbooks Paper, IBM 2002. |
Gregg, T.A., “S/390 CMOS Server I/O: The Continuing Evolution”, IBM J. Res. Develop. vol. 41, No. 4/5, Jul./Sep. 1997. |
IBM, Inc., “OSA-Express Customer's Guide and Reference”, p. 3-10, 2003-2006. |
Zee, et al., “IBM System z9 Open Systems Adapter for Communication Controller for Linux,” IBM J. Res. Develop. vol. 51, No. 1/2, Jan./Mar. 2007. |
Number | Date | Country | |
---|---|---|---|
20120296625 A1 | Nov 2012 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 12355903 | Jan 2009 | US |
Child | 13563776 | US |