Interrupt-Driven System Verification Method Based on Interrupt Sequence Diagram
20220317976 · 2022-10-06
Inventors
- Minxue PAN (Jiangsu, CN)
- Shouyu CHEN (Jiangsu, CN)
- Tian ZHANG (Jiangsu, CN)
- Linzhang WANG (Jiangsu, CN)
- Xuandong LI (Jiangsu, CN)
Cpc classification
International classification
Abstract
An interrupt-driven system verification method based on interrupt sequence diagrams includes the steps of: establishing an interrupt-driven system model based on an interrupt sequence diagram, dividing interaction fragments in the obtained interrupt sequence diagram into basic interaction fragments and composite interaction fragments and sequentially converting the basic interaction fragments and the composite interaction fragments into the corresponding automaton models, combining the automaton models into one automaton model, adding the constraints in the interrupt sequence diagram to the converted automaton model, adding the verification attribute information as a constraint to the converted automaton model, describing an automaton as an input format acceptable to the automaton verification tool, and verifying the model with the automaton verification tool.
Claims
1. An interrupt-driven system verification method based on an interrupt sequence diagram, characterized by comprising the steps of: Step 1, establishing an interrupt-driven system model based on an interrupt sequence diagram, wherein the interrupt sequence diagram is comprised of interaction objects, interaction fragments, constraints and verification attributes; providing that an interaction event within interrupt combined fragments and an event outside the interrupt combined fragments have no temporal partially-ordered relation because when interrupts may happen and get processed are uncertain; in terms of a priority of the interrupts, providing that execution of an interrupt fragment with a high priority can break execution of an interrupt with a low priority, but the execution of the interrupt with the low priority cannot break the execution of the interrupt with the high priority; in terms of a conditional expression, providing that if the conditional expression is true, then a interrupt task can be triggered, otherwise, the interrupt task cannot be triggered; Step 2, dividing the interaction fragments in the interrupt sequence diagram obtained in step 1 into basic interaction fragments and composite interaction fragments; Step 3, sequentially converting the basic interaction fragments and the composite interaction fragments into corresponding automaton models; Step 4, combining the automaton models obtained in step 3 into one automaton model, whereby a converted automaton model from the interrupt-driven model is obtained; Step 5, extracting the constraints in the interrupt sequence diagram, and adding the constraints to the converted automaton model; Step 6, extracting the verification attribute in the interrupt sequence diagram, and adding the verification attribute as a constraint to the converted automaton model; Step 7, describing an automaton as an input format acceptable to an automaton verification tool; and Step 8, verifying with the automaton verification tool.
2. The interrupt-driven system verification method based on the interrupt sequence diagrams according to claim 1, characterized in that: the interrupt sequence diagram in step 1 is a two-dimensional diagram; the interaction objects are listed along the horizontal axis sequentially; the vertical axis indicates time increasing vertically downwards and is used for describing a time sequence of the interaction objects; the interaction objects are represented as lifelines, and the interaction among the objects is described as messages; the message is a communication mechanism among objects wherein a sending object sends a signal to another receiving object or several other receiving objects, an arrow is used for describing a transmission process of the message, a name of the message is marked above and below a line with the arrow, and sending and receiving events of the message have unique event names marked at a starting point and an ending point of the line with the arrow; a complex control flow in the interrupt sequence diagram is represented as combined fragments having their functions determined respectively by a type of interaction operations thereof, where “loop” represents a loop operation, “alt” represents an alternative operation, “opt” represents an optional operation, the same as in a UML sequence diagram; “int”, however, is an additional operation of the interrupt sequence diagram to the UML sequence diagram, where a boundary of the combined fragments is also represented as a box, at an upper left corner of which a character string “int” indicates that the type of the combined fragments is an interrupt operation, p indicates the priority of the interrupt, id is a name of the interrupt combined fragments, and “condition” is a conditional expression indicating a condition under which an interrupt occurs.
3. The interrupt-driven system verification method based on an interrupt sequence diagram according to claim 1, characterized in that a method for converting the basic interaction fragments and the composite interaction fragments into corresponding automaton models in step 3 comprises the steps of: 1) for the basic interaction fragments, representing a basic interaction sequence as a quadruple BIS=(O, M, E, V), where O represents an interaction object set, M represents a message set, E represents an event set, and V represents a partial-ordered relationship among interaction events, obtaining a set T of traces of the interaction sequence on this basis, and then conducting conversion based on an algorithm, wherein: firstly, an initial state q0 is generated, a set L is a set of events that occur during a plurality of transitions from the state q0 to a state q, events without precursor events or with precursor events in the set L are found out in the set E-L to generate new transitions and states, and each set is updated to continue iteration until no new transitions and states are generated anymore; identical state nodes in the set L are merged in the process of generating the automaton, as a result, a simplest automaton is generated; and 2) for the composite interaction fragments, generating a corresponding automaton based on the interaction sequence therein according to the method of converting the basic interaction fragments, wherein q0 is an initial state and qn is a final state, and completion of the generation of the automaton depends on to different types of the combined fragments, which is implemented as follows: 21) for loop combined fragments, there has to be at least a times and at most b times of loops, at first, two new position nodes q and qf are generated, meanwhile, a control variable i is generated and keeps unchanged at any state node, and then a transition
4. The interrupt-driven system verification method based on an interrupt sequence diagram according to claim 1, characterized in that: a method of combining a plurality of automata generated in step 3 into one automaton in step 4 comprises the steps of: 1) combining all other interaction fragments except the interrupt combined fragments into one automaton, where the automatons corresponding to these interaction fragments are combined according to and because of relationships among the interaction fragments, and for the automata A and B, all the events corresponding to the automaton A occur prior to all the events in the automaton B; the steps of combining are as follows: 11) a final state qa of the automaton A is combined with an initial state lb of the automaton B, and a resulting state is marked as q; 12) any transition (l, e, qa) in the automaton A is changed to (l, e, q), wherein l is a state in the automaton A, and e is an event in the automaton A; and 13) any transition (lb, e′, l′) in the automaton B is changed to (q, e′, l′), wherein l′ is a state in the automaton B, and e′ is an event in the automaton B; and 2) combining an automaton model corresponding to the interrupt combined fragments into the automaton generated in step 1); a non-interrupt interaction fragment is regarded as an interaction fragment with a priority of 0, any other interrupt can break a task execution of the non-interrupt interaction fragment, and the steps of combining are as follows: 21) a high-priority automaton is connected into a low-priority automaton according to a principle that a high-priority task breaks a low-priority task; provided that the priority of automaton A is 1 and the priority of automaton B is 2, a state of the automaton B can occur after any state of automaton A; q is any state node of the automaton A, 10 is a initial state node of the automaton B, ln is an final state node of the automaton B, and the new transitions, i.e.,
5. The interrupt-driven system verification method based on an interrupt sequence diagram according to claim 1, characterized in that: a method in step 5 of adding constraints to the automaton obtained in step 4 comprises the steps of: 1) generating a clock variable c for each common time constraint, and the clock variable c be capable of increasing in time at any state node; providing that the time constraint is e.sub.y−e.sub.x<a which indicates that event e.sub.y must be completed within a time units after event e.sub.x occurs; setting the clock variable c to be 0 for all event sequences when the event e.sub.x occurs, and adding a conversion guard c<a when the event e.sub.y occurs to indicate that the transition can happen and the automaton reaches a next state only when the condition is satisfied; and 2) generating a clock variable c for each project time constraint; indicating by a project time constraint (e.sub.y−e.sub.x)↑<a that the event e.sub.y must be completed within a time units after event e.sub.x occurs, the “a time units” excluding a running time of an interrupt task, wherein, at this time, the clock variable c increases in time at all the state nodes of the automaton where the events e.sub.y and e.sub.x are positioned, but remains unchanged at the other state nodes of the automaton; similarly, setting the clock variable c to be 0 for all event sequences when event e.sub.x occurs, pausing the clock when an interrupt occurs because a rate of change of the clock variable c at other state nodes is 0, restarting the clock when the interrupt task ends and a current task execution sequence is restored, and adding a transition guard c<a when event e.sub.y occurs to indicate that the transition can happen and the automaton reaches a next state only when the condition is satisfied.
6. The interrupt-driven system verification method based on an interrupt sequence diagram according to claim 1, characterized in that: a method in the step 6 of adding the verification attribute into the automaton obtained in step 4 comprises, getting a negation of the expressions describing a task timeout attribute and a data consistency attribute, and adding the negative expressions into the automaton as time constraint expressions according to the method described in step 5 into the automaton.
7. The interrupt-driven system verification method based on an interrupt sequence diagram according to claim 1, characterized in that: a method in step 7 of describing the automaton as an input format acceptable to the automaton verification tool comprises converting information of the automaton obtained in step 6 into a file format acceptable to the verification tool.
8. The interrupt-driven system verification method based on an interrupt sequence diagram according to claim 1, characterized in that: a method for generating automata corresponding to different interaction fragments in the interrupt sequence diagram are provided firstly, which can be applicable to the verification of the interrupt-driven system.
9. The interrupt-driven system verification method based on an interrupt sequence diagram according to claim 2, characterized in that: the interrupt sequence diagram is subjected to an overall analysis, the automata generated for different interaction fragments are combined into a complete automaton according to a strategy of combining in step 4, and constraints and the verification attribute are added into the automaton.
10. The interrupt-driven system verification method based on an interrupt sequence diagram according to claim 1, characterized in that: the interrupt sequence diagram model is converted into a corresponding automaton model, and the interrupt sequence diagram model is indirectly verified with the verification tool of the automaton model, helping developers with modeling and verification.
Description
BRIEF DESCRIPTION OF THE DRAWINGS
[0036]
[0037]
[0038]
[0039]
[0040]
[0041]
[0042]
[0043]
[0044]
DETAILED DESCRIPTION OF THE INVENTION
[0045] The detailed process of model conversion and model verification using this method is described below in conjunction with a simple interrupt sequence diagram model.
[0046] A method for verifying an interrupt-driven system based on an interrupt sequence diagram in the embodiment is illustrated. 1) An interrupt sequence diagram model example introduced. This model is shown in
are added, after this, q and qn are taken as new initial and final states, respectively, and the resulting automaton is shown in
(q8 and q10 are the initial and final states, respectively, of the interrupt IRQ1), where gMacher is used for recording a unique matching mark of incoming and outgoing edges thereof, and macher is used for recording a matching mark before entering the high priority automaton; this is done for all other state nodes, and similarly for IRQ2, it should be noted that IRQ2 can break not only the basic interaction fragment, but also IRQ1. The resulting automaton model is shown in
[0139] The foregoing is only a preferred embodiment of the present invention, and it should be noted that it will be apparent to those skilled in the art that various modifications and variations can be made in the present invention without departing from the spirit or scope of the invention.