420 likes | 488 Views
Communicating Transaction Processes. P.S. Thiagarajan National University of Singapore Joint Work with: Abhik Roychoudhury; ……. The Main Features. To support System Level Design One Level of Abstraction higher than C, C++, VHDL .. UML-compatible MSCS + Asynchronous control flow
E N D
Communicating Transaction Processes P.S. Thiagarajan National University of Singapore Joint Work with: Abhik Roychoudhury; …… ES Seminar
The Main Features • To support System Level Design • One Level of Abstraction higher than C, C++, VHDL .. • UML-compatible • MSCS + Asynchronous control flow • Based on MSCs (Message Sequence Charts) • Sequence Diagrams ES Seminar
Why System Level Design? • Closer to end-use(r) . • Less detailed and more architecture-neutral. • Easier reuse/adaptaton. • Easier to verify. • Safety-critical applications need to be correct. • Catch design errors early. • Coupling with a correct-by-construction synthesis method is an attractive option. ES Seminar
What is Available? • Data flow graphs. • Automata of various kinds. • Petri nets. • State charts. • Esterel, Lustre. • SDL, UML. ES Seminar
Why UML-compatible? • UML is getting rapidly established as a standard. • Mainly in software engineering projects • Increasingly so in embedded systems domain. • Offers a suite of graphical notations: • Multiple views • Behavioral and structural diagrams. • Object orientation. • Reuse, adaptation ES Seminar
An Idealized Design Flow Requirements High Level Description Exec. Specifications. Intermediate representation SW/HW Implementation. ES Seminar
Requirements and Exec. Specifications • Requirements : Message Sequence Charts (MSCs) • Exec. Specifications : • State charts. • UML supports both but no clear distinction made. • Other Exec. Spec. : • Petri nets, • MPAs (Message Passing Automata), …. ES Seminar
MSCs • Message Sequence Charts: • Describe scenarios. • A finite pattern of interaction between agents (object instances,..). • A story ES Seminar
Message Sequence Charts U1 R U2 rq rq y n ES Seminar
Message Sequence Charts U1 R U2 rq rq y n ES Seminar
Message Sequence Charts U1 R U2 rq rq y internal action n ES Seminar
Message Sequence Charts U1 R U2 rq rq internal actions y n ES Seminar
Message Sequence Charts U1 R U2 rq rq y n ES Seminar
Message Sequence Charts U1 R U2 rq rq y n ES Seminar
Message Sequence Charts U1 R U2 rq rq y n ES Seminar
Message Sequence Charts U1 R U2 rq rq y n ES Seminar
Message Sequence Charts U1 R U2 rq rq y n ES Seminar
Message Sequence Charts U1 R U2 rq rq n y ES Seminar
Message Sequence Charts U1 R U2 rq rq y n ES Seminar
Message Sequence Charts U1 R U2 rq rq y n ES Seminar
Message Sequence Charts U1 R U2 rq rq y n ES Seminar
CTPs • Communicating Transaction Processes. • An executable spec. mechanism. • Based on MSCs. • A network of interacting agents. • Agent’s interaction pattern behavior: • Standard distributed system model • Interaction: • Guarded choice of MSCs. • Transaction schemes. ES Seminar
Distributed System Models • Petri nets • Data flow graphs • Statecharts • Distributed transition systems (many kinds!) • Process algebras (CCS, CSP, …) ES Seminar
I2 I1 PI2 PI1 IB1 IB2 B P2 ES Seminar
I2 I1 PI2 PI1 IB1 IB2 B P2 ES Seminar
I2 I1 PI2 PI1 IB1 IB2 B P2 ES Seminar
I2 I1 PI2 PI1 IB1 IB2 B P2 ES Seminar
I2 I1 PI2 PI1 IB1 IB2 B P2 ES Seminar
I2 I1 PI2 PI1 IB1 IB2 B P2 But the boxes will have internal structure. A complex Transaction Scheme. ES Seminar
Transaction Scheme I2 B I2 B I2 B 2data.present & B.free 2data.present & B.free 2data.present req req y n add data waitcount2:= waitcount2 + 1 ES Seminar
I2 I1 PI2 PI1 IB1 IB2 B 2data.present & B.free req y add data ES Seminar
I2 I1 2data.present & B.free req PI2 y PI1 IB1 IB2 add data B ES Seminar
I2 I1 2data.present & B.free req PI2 y PI1 IB1 IB2 add data B ES Seminar
I2 I1 2data.present & B.free req PI2 y PI1 IB1 IB2 add data B ES Seminar
I2 I1 2data.present & B.free req PI2 y PI1 IB1 IB2 add data B ES Seminar
I2 I1 2data.present & B.free req PI2 y PI1 IB1 IB2 add data B ES Seminar
I2 I1 2data.present & B.free req PI2 y PI1 IB1 IB2 add data B ES Seminar
I1 P11 P11 Transaction Scheme I1 1data.present 1data.present 1data.present no-op data no-data 1data.present 1data.present 1data.present ES Seminar
Determine whether a CTP is bounded. Determine if a CTP can deadlock. Determine if a CTP is well-formed. Analysis Issues ES Seminar
Current Status Case Studies Modeling The CTP Model Verification Analysis SMV ES Representation Simulation; Synthesis Verilog
Current Status Pankaj Jain Nikhil Jain Kamrul Hasan Talukdar Tran Tuan Anh Ge Zhiguo Case Studies Modeling The CTP Model Verification Analysis SMV ES Representation Simulation; Synthesis Verilog
Future Work • Add multiple instances of a process. • Object features • Add timing constraints. • Develop the computational model. • Interactions with environment (sense, actuate) • Computational steps (control law) • Schedulability is a key issue. • HW/SW Partitioning; Architectural mapping; Synthesis? ES Seminar