A grammar-based methodology for protocol specification and implementation

A new methodology for specifying and implementing communication protocols is presented. This methodology is based on a formalism called “Real-Time Asynchronous Grammars” (RTAG), which uses a syntax similar to that of attribute grammars to specify allowable message sequences. In addition RTAG provides mechanisms for specifying data-dependent protocol activities, real-time constraints, and concurrent activities within a protocol entity. RTAG encourages a top-down approach to protocol design that can be of significant benefit in expressing and reasoning about highly complex protocols. As an example, an RTAG specification is given for part of the Class 4 ISO Transport Protocol (TP-4). Because RTAG allows protocols to be specified at a highly detailed level, major parts of an implementation can be automatically generated from a specification. An RTAG parser can be written which, when combined with an RTAG specification of a protocol and a set of interface and utility routines, constitutes an implementation of the protocol. To demonstrate the viability of RTAG for implementation generation, an RTAG parser has been integrated into the kernel of the 4.2 BSD UNIX operating system, and has been used in conjunction with the RTAG TP-4 specification to obtain an RTAG-based TP-4 implementation in the DoD Internet domain.

[1]  Ed Brinksma,et al.  A tutorial on LOTOS , 1985, PSTV.

[2]  Thomas P. Blumer,et al.  A Formal Specification Technique and Implementation Method for Protocols , 1982, Comput. Networks.

[3]  Yechiam Yemini,et al.  CUPID: A Protocol Development Environment , 1983, Protocol Specification, Testing, and Verification.

[4]  F. D. Smith,et al.  A Meta-Implementation for Systems Network Architecture , 1982, IEEE Trans. Commun..

[5]  Ming T. Liu,et al.  A formal approach to the desin and implementation of network communication protocol , 1978, COMPSAC.

[6]  Deepinder P. Sidhu,et al.  Verification of NBS Class 4 Transport Protocol , 1986, IEEE Trans. Commun..

[7]  Carl A. Sunshine Formal Modeling of Communication Protocols - State of the Art , 1981, Kommunikation in Verteilten Systemen.

[8]  Robin Milner,et al.  A Calculus of Communicating Systems , 1980, Lecture Notes in Computer Science.

[9]  C. H. West,et al.  Executable Description and Validation of SNA , 1980, IEEE Trans. Commun..