Showing posts with label specman e-language. Show all posts
Showing posts with label specman e-language. Show all posts
Friday, August 5, 2011
Protocol Checkers for DUT state machine
In order to write a Protocol Checker for the DUT state machine we need to do the following
1. Declare an enumerated type having the same propreties as of the DUT enumerated type.
2. Declare an e-port may be of simple port of inout type
3. Declare an e-event for the corresponding DUT state machine value.
4. on the emission of the event check the required condition . If it satisfied continue else come out with DUT ERROR.
Ex :
type state_t : [ IDLE, SHIFT, SAMPLE];
unit monitor_u {
state_sig_port : inout simple_port of uint is instance;
keep bind ( state_sig_port, external );
keep state_sig_port.hdl_path() == "/top/state_s";
event state_sig_port_shift_e is true ( state_sig_port.as_a(state_t) == SHIFT) @clk_rise;
event en_sig_e is rise (en_sig$) @clk_rise;
expect @state_sig_port_shift_e =>{ @en_sig_e } @clk_rise else dut_error ("......");
1. Declare an enumerated type having the same propreties as of the DUT enumerated type.
2. Declare an e-port may be of simple port of inout type
3. Declare an e-event for the corresponding DUT state machine value.
4. on the emission of the event check the required condition . If it satisfied continue else come out with DUT ERROR.
Ex :
type state_t : [ IDLE, SHIFT, SAMPLE];
unit monitor_u {
state_sig_port : inout simple_port of uint is instance;
keep bind ( state_sig_port, external );
keep state_sig_port.hdl_path() == "/top/state_s";
event state_sig_port_shift_e is true ( state_sig_port.as_a(state_t) == SHIFT) @clk_rise;
event en_sig_e is rise (en_sig$) @clk_rise;
expect @state_sig_port_shift_e =>{ @en_sig_e } @clk_rise else dut_error ("......");
Monday, June 7, 2010
Temporal checker using e language
Temporal Checker mainly depends on the Temporal Expressions ( TE's) and these are directed statments ( one line statement) with major reference to Reference clocks.
For ex :
I have shown a small example which expects certain event to be emitter based on the following conditions.
<'
unit bus_u {
event bus_clk is change('clk') @sim;
event transmit_start is rise('transcation_done') @bus_clk;
event transmit_end is rise('transmit_done') @bus_clk;
event bus_cycle_length;
on transmit_start {
out ("found the transmit_start event...", sys.time);
};
expect bus_cycle_length is @transmit_start => {[0..9];@transmit_end} @bus_clk
else dut_error("Bus cycle did not end in 10 cycles");
};
extend sys {
bus : bus_u is instance; keep bus.hdl_path() == "top";
};
'>
For ex :
I have shown a small example which expects certain event to be emitter based on the following conditions.
<'
unit bus_u {
event bus_clk is change('clk') @sim;
event transmit_start is rise('transcation_done') @bus_clk;
event transmit_end is rise('transmit_done') @bus_clk;
event bus_cycle_length;
on transmit_start {
out ("found the transmit_start event...", sys.time);
};
expect bus_cycle_length is @transmit_start => {[0..9];@transmit_end} @bus_clk
else dut_error("Bus cycle did not end in 10 cycles");
};
extend sys {
bus : bus_u is instance; keep bus.hdl_path() == "top";
};
'>
Thursday, August 6, 2009
combination between Method & TCM in Specman Environment
Currently we can see the Combination exists between the Methods & TCM in Specman Environment.
TCM :
TCM can Start another TCM ( Using start keyword )
TCM can call another Method .
Methods :
Methods can start TCM.
Methods can call another Method.
Methods cannot call a TCM.
TCM :
TCM can Start another TCM ( Using start keyword )
TCM can call another Method .
Methods :
Methods can start TCM.
Methods can call another Method.
Methods cannot call a TCM.
Thursday, May 7, 2009
Time Consuming Method (TCM) in specman e-language
TCM's are defined as the methods that have the notion of time, as designated by their sampling event.
· TCM's can be executed over several simulation cycles.
Syntax:
tcm_name([arg: type,...]) [:return-type] @sampling-event is {
---- Required action parameters;
};
TCM’s are attached with sampling_event. The sampling_event fills two functions.
· Implicit sync action at beginning of TCM( must occur before TCM execution begins)
· Default sampling event for TEs in the TCM
Ex: <'
unit port_u {
reset_value: bit;
reset_delay: uint;
reset () @clk is {
---- This indicates the TCM is @sync with clk
reset_value = 0b1;
wait [reset_delay] * cycle;
reset_value = 0b0;
wait [1] * cycle;
};
run() is also {
start reset();
}; };
'>
· TCM's can be executed over several simulation cycles.
Syntax:
tcm_name([arg: type,...]) [:return-type] @sampling-event is {
---- Required action parameters;
};
TCM’s are attached with sampling_event. The sampling_event fills two functions.
· Implicit sync action at beginning of TCM( must occur before TCM execution begins)
· Default sampling event for TEs in the TCM
Ex: <'
unit port_u {
reset_value: bit;
reset_delay: uint;
reset () @clk is {
---- This indicates the TCM is @sync with clk
reset_value = 0b1;
wait [reset_delay] * cycle;
reset_value = 0b0;
wait [1] * cycle;
};
run() is also {
start reset();
}; };
'>
Wednesday, April 22, 2009
Declaration of Specman e-language Basic Temporal Expressions
Cadence Specman Elite e-language TE (Temporal Expression), is always associated with a sampling event indicating when the Temporal Expression needs to be evaluated by Specman elite e-language.
1) true(Boolean-exp)@sample-event
The above expression indicates for every Sample-event that the Boolean Expression is true.
2) rise/fall/change (exp)@sample-event
The above expression indicates for every Sample-event that the Expression is rising (falling/change).
3) Cycle @sample-event
The above Expression indicates for every sampling event.
4) [Number] * TE
The above expression indicates the TE’s is repeated for number of times.
1) true(Boolean-exp)@sample-event
The above expression indicates for every Sample-event that the Boolean Expression is true.
2) rise/fall/change (exp)@sample-event
The above expression indicates for every Sample-event that the Expression is rising (falling/change).
3) Cycle @sample-event
The above Expression indicates for every sampling event.
4) [Number] * TE
The above expression indicates the TE’s is repeated for number of times.
Wednesday, April 15, 2009
Importance Of Using Sampling Events in specman elite e-language
In order to  drive / sample  signals  correctly, there is a need to  synchronize with the simulator. 
To achieve the above task there is a need to make use of the Specman elite Temporal Language Expression.
The Temporal language of the e-language is the basis for capturing behavior over time for below purpose:
-> To synchronizing with the DUT.
-> In order to develop protocol checkers for automation.
-> In order to develop a Functional coverage for better understanding of the scenarios.
The Temporal Language is mainly built using the below concept:
-> Temporal expressions (TEs)
-> Temporal operators, for defining complex expressions.
-> Event struct members, for defining occurrences of events during the run.
-> Expect struct members, for checking temporal behavior
To achieve the above task there is a need to make use of the Specman elite Temporal Language Expression.
The Temporal language of the e-language is the basis for capturing behavior over time for below purpose:
-> To synchronizing with the DUT.
-> In order to develop protocol checkers for automation.
-> In order to develop a Functional coverage for better understanding of the scenarios.
The Temporal Language is mainly built using the below concept:
-> Temporal expressions (TEs)
-> Temporal operators, for defining complex expressions.
-> Event struct members, for defining occurrences of events during the run.
-> Expect struct members, for checking temporal behavior
Tuesday, April 14, 2009
Accessing / Sampling the DUT signals using specman elite e-language
Specman elite e-language supports in driving or sampling 
-> VHDL signals at any hierarchy level
-> Verilog registers and wires at any hierarchy level.
In order to access the DUT we need to use single quotes with '~' to denote top-level module name.
'~/instance HDL path/signal name‘  
Ex:
‘~/top_tb/data_in’
Here the top_tb refers to the Top HDL module name and data_in refers to the signal name present in the top_tb module.
-> To Drive a Value from Specman elite e-language to DUT, apply the following mechanism.
‘~/top_tb/reset’ = 1;
-> To Sample a DUT value to Specman elite Variables ( Struct / Unit) , apply the following mechanism.
Packet_u.data_out = ‘~/top_tb/data_out”;
-> VHDL signals at any hierarchy level
-> Verilog registers and wires at any hierarchy level.
In order to access the DUT we need to use single quotes with '~' to denote top-level module name.
'~/instance HDL path
Ex:
‘~/top_tb/data_in’
Here the top_tb refers to the Top HDL module name and data_in refers to the signal name present in the top_tb module.
-> To Drive a Value from Specman elite e-language to DUT, apply the following mechanism.
‘~/top_tb/reset’ = 1;
-> To Sample a DUT value to Specman elite Variables ( Struct / Unit) , apply the following mechanism.
Packet_u.data_out = ‘~/top_tb/data_out”;
specman elite e-language supports creation of Bus Functional Module (BFM)
Specman elite e-language supports the creation of Bus Functional Module , Popularly known as BFM.
In order to construct BFM targeting the DUT (Design Under Test), we need to use e-language Temporal Expressions using the concept of TCM ( Time Consuming Methods).
The TCM is similar to Methods , but supported with the events and other Temporal related expressions like wait, sync...
The Initial TCM needs to be started to execute the defined functionality ( which in turn may call / start other dependent TCM's).
e.g
<'
unit packet_bfm_u {
// definition of fields
// Declaration of TCM
packet_gen() @clk_rise is {
// Apply the packet generation functionality
} ; // end of TCM def
run() is also {
// start the TCM
start packet_gen();
};
'>
In order to construct BFM targeting the DUT (Design Under Test), we need to use e-language Temporal Expressions using the concept of TCM ( Time Consuming Methods).
The TCM is similar to Methods , but supported with the events and other Temporal related expressions like wait, sync...
The Initial TCM needs to be started to execute the defined functionality ( which in turn may call / start other dependent TCM's).
e.g
<'
unit packet_bfm_u {
// definition of fields
// Declaration of TCM
packet_gen() @clk_rise is {
// Apply the packet generation functionality
} ; // end of TCM def
run() is also {
// start the TCM
start packet_gen();
};
'>
Sunday, April 12, 2009
Advantage of using Specman Elite stimulus variation feature
The Specman elite  e-language stimulus Variation concept mainly helps in,
· Reusability
· Maintainability
· Extendibility
An Approach to Creating SUBTYPES using e-language:
Consider a Network Packet example having address, length, data as its fields and using the defined fileds need to calculate parity . The defined Network Packet may be either GOOD or BAD.
Whenever the packet is of type GOOD assign the parity calculated to parity field and if the packet is of type BAD then do not assign the parity to the parity field.
In order to achieve the required condition, we need to create a subtype using when inheritance.
Following are the steps to be taken while creating subtypes.
· Define a new enumerated type (i.e. Good and Bad)
· Define a field on enumerated type in the struct to represent various subtypes.
· Write a when block and add struct members in the when block that correspond to properties of the specific subtypes.
filename : packet.e
<’
---- Declaration of enumerated types
type packet_kind_t: [Good, Bad];
struct packet_s {
pkt_Kind: packet_kind_t;
Address : uint (bits: 2);
Length : uint (bits: 6);
Data : list of byte;
Keep data. size () = = length;
Parity : byte;
---- User Method for calculating parity Value
Parity_calc () : byte is {
----- User Actions Needs to be entered for calculating parity;
};
--- Subtype creation
When Good ‘pkt_kind packet_s {
Keep parity = = parity_calc ();
};
When Bad ‘pkt_kind packet_s {
Keep parity! = Parity_calc ();
};
};
‘> ---- End of struct
filename : packet_top.e
<'
import packet.e;
extend sys {
packet : packet_s ;
};
'>
filename : packet_test.e
<'
import packet_top.e;
// For Writing Test cases using constraint use the extend feature supported by e-language
extend packet_s {
// Apply the Constraints Required
keep soft pkt_kind == GOOD;
keep soft length == 10;
keep soft Address in [0x1000..0x2000];
};
'>
· Reusability
· Maintainability
· Extendibility
An Approach to Creating SUBTYPES using e-language:
Consider a Network Packet example having address, length, data as its fields and using the defined fileds need to calculate parity . The defined Network Packet may be either GOOD or BAD.
Whenever the packet is of type GOOD assign the parity calculated to parity field and if the packet is of type BAD then do not assign the parity to the parity field.
In order to achieve the required condition, we need to create a subtype using when inheritance.
Following are the steps to be taken while creating subtypes.
· Define a new enumerated type (i.e. Good and Bad)
· Define a field on enumerated type in the struct to represent various subtypes.
· Write a when block and add struct members in the when block that correspond to properties of the specific subtypes.
filename : packet.e
<’
---- Declaration of enumerated types
type packet_kind_t: [Good, Bad];
struct packet_s {
pkt_Kind: packet_kind_t;
Address : uint (bits: 2);
Length : uint (bits: 6);
Data : list of byte;
Keep data. size () = = length;
Parity : byte;
---- User Method for calculating parity Value
Parity_calc () : byte is {
----- User Actions Needs to be entered for calculating parity;
};
--- Subtype creation
When Good ‘pkt_kind packet_s {
Keep parity = = parity_calc ();
};
When Bad ‘pkt_kind packet_s {
Keep parity! = Parity_calc ();
};
};
‘> ---- End of struct
filename : packet_top.e
<'
import packet.e;
extend sys {
packet : packet_s ;
};
'>
filename : packet_test.e
<'
import packet_top.e;
// For Writing Test cases using constraint use the extend feature supported by e-language
extend packet_s {
// Apply the Constraints Required
keep soft pkt_kind == GOOD;
keep soft length == 10;
keep soft Address in [0x1000..0x2000];
};
'>
Saturday, April 11, 2009
Specman elite example for creating subtype packet structure
The below example demonstrates how to generate WR only packet using specman elite e-language without applying the constraints to the enumerated fields declared.
< '
type packet_wr_rd_t : [ WR, RD];
struct packet_s {
packet_wr_rd : packet_wr_rd_t ; // Declaration of the field
Address : byte ; // Common field for both RD / WR
keep soft Address == 0x10;// Apply the Subtype to control the generation
when WR' packet_s {
wr_data : byte ; // default value, can be overwritten using testcase
keep soft wr_data == 0x0 ;
}; // end of WR subtype creation.
}; // end of struct definition
'>
filename : packet_top.e
<'
extend sys {
// The below assignment make sure that only WR related Packet is generated, which is indirect
// way of applying the constraints
pkt : WR packet_s;
};
'>
< '
type packet_wr_rd_t : [ WR, RD];
struct packet_s {
packet_wr_rd : packet_wr_rd_t ; // Declaration of the field
Address : byte ; // Common field for both RD / WR
keep soft Address == 0x10;// Apply the Subtype to control the generation
when WR' packet_s {
wr_data : byte ; // default value, can be overwritten using testcase
keep soft wr_data == 0x0 ;
}; // end of WR subtype creation.
}; // end of struct definition
'>
filename : packet_top.e
<'
extend sys {
// The below assignment make sure that only WR related Packet is generated, which is indirect
// way of applying the constraints
pkt : WR packet_s;
};
'>
Friday, April 10, 2009
specman elite e-language supports subtype stimulus creation
Specman elite e-language supports the formation of subtype stimulus creation.
In order to achieve we need to use the enumerated define types.
e.g If we want to control the generation of fields w.r.t subtypes, it is better to use enumerated types as a controlling parameters.
Let's have requirements in mind for the Read / Write scenario. We all Know that Address field is common for both Read / Write Transcation, whereas we need to generated write data when we are performing the Write Transcation.
Here is how we control the generation using the specman e-language subtype declaration.
The following example demonstrates , if the enumerate type declared is WR in nature it generates Write Address and Write Data else it only performs Read Transcation.
< '
type packet_wr_rd_t : [ WR, RD];
struct packet_s {
packet_wr_rd : packet_wr_rd_t ; // Declaration of the field
keep soft packet_wr_rd == WR;
Address : byte ; // Common field for both RD / WR
keep soft Address == 0x10;
// Apply the Subtype to control the generation
when WR' packet_s {
wr_data : byte ;
// default value, can be overwritten using testcase
keep soft wr_data == 0x0 ;
}; // end of WR subtype creation.
}; // end of struct definition
'>
In order to achieve we need to use the enumerated define types.
e.g If we want to control the generation of fields w.r.t subtypes, it is better to use enumerated types as a controlling parameters.
Let's have requirements in mind for the Read / Write scenario. We all Know that Address field is common for both Read / Write Transcation, whereas we need to generated write data when we are performing the Write Transcation.
Here is how we control the generation using the specman e-language subtype declaration.
The following example demonstrates , if the enumerate type declared is WR in nature it generates Write Address and Write Data else it only performs Read Transcation.
< '
type packet_wr_rd_t : [ WR, RD];
struct packet_s {
packet_wr_rd : packet_wr_rd_t ; // Declaration of the field
keep soft packet_wr_rd == WR;
Address : byte ; // Common field for both RD / WR
keep soft Address == 0x10;
// Apply the Subtype to control the generation
when WR' packet_s {
wr_data : byte ;
// default value, can be overwritten using testcase
keep soft wr_data == 0x0 ;
}; // end of WR subtype creation.
}; // end of struct definition
'>
Thursday, April 9, 2009
specman e-language constraint usage example
Adding a small example for using the constraint feature with the help of specman elite e-language.
file name : packet_def.e
<'
packet_kind_t : [ small, medium, large]
'>
file name : packet.e
<’
struct packet_s {
Addr: uint (bits: 32);
Kind: packet_kind_t;
my_method () is {
// define the actions required e.g parity_calculation
};
file name : packet_def.e
<'
packet_kind_t : [ small, medium, large]
'>
file name : packet.e
<’
struct packet_s {
Addr: uint (bits: 32);
Kind: packet_kind_t;
my_method () is {
// define the actions required e.g parity_calculation
};
// call the above mentioned method in run phase
run() is also {
my_method();
};
}; // end of struct def
'>
file name : packet_top.e
<'
import packet_def.e;
import packet.e;
extend sys {
pkt : packet_s ;
};
'>
// Writing the Top Test case for applying constraints
file name : packet_test.e
<'
import packet_top.e;
extend packet_s {
keep soft Kind = = Small ;
                         keep soft addr  in [10..40];
                           }; 
           ‘>
Wednesday, April 8, 2009
specman elite possible ways of generating fields
Specman Elite e-language supports three possible ways of generating the fields.
· Random generation
· Directed-Random generation
· Directed generation
Random generation:
The Random generation is not supported by constraints.
Ex: address: int (bits: 32);
Directed-Random generation:
The Directed-Random generation supports the generation by constraining to a range of values. Here, even though the generation is random it is been restricted within the Range of 1000 to 2000 address locations.
Ex: keep address in [0x1000..0x2000];
Directed generation:
The Directed generation supports the generation by constraining to a specific value.Here, the generation of address value is specified to the location of 1245.
Ex: keep address = = 0x1245;
Soft Constraints
For constraints that might need to be overridden, we use soft constraints. Basically, Soft constraints are obeyed if not contradicted by hard constraints.
The last loaded soft constraint prevails if there is a contradiction with other soft constraints.
Syntax :
keep soft Boolean-expression;
Ex: keep soft length = = 64;
· Soft constraints are used to define the default range of values of fields:
Ex: keep soft packet_length in [60..100];
· The test writer has the option to ignore the soft constraint by using predefined method reset_soft().
Ex: keep packet_length.reset_soft ();
· Soft constraints are used to set initial settings for tests
Ex: keep soft errors = = FALSE;
· Random generation
· Directed-Random generation
· Directed generation
Random generation:
The Random generation is not supported by constraints.
Ex: address: int (bits: 32);
Directed-Random generation:
The Directed-Random generation supports the generation by constraining to a range of values. Here, even though the generation is random it is been restricted within the Range of 1000 to 2000 address locations.
Ex: keep address in [0x1000..0x2000];
Directed generation:
The Directed generation supports the generation by constraining to a specific value.Here, the generation of address value is specified to the location of 1245.
Ex: keep address = = 0x1245;
Soft Constraints
For constraints that might need to be overridden, we use soft constraints. Basically, Soft constraints are obeyed if not contradicted by hard constraints.
The last loaded soft constraint prevails if there is a contradiction with other soft constraints.
Syntax :
keep soft Boolean-expression;
Ex: keep soft length = = 64;
· Soft constraints are used to define the default range of values of fields:
Ex: keep soft packet_length in [60..100];
· The test writer has the option to ignore the soft constraint by using predefined method reset_soft().
Ex: keep packet_length.reset_soft ();
· Soft constraints are used to set initial settings for tests
Ex: keep soft errors = = FALSE;
Monday, April 6, 2009
Controlling order of generation using specman e-language
Specman elite e-language generates the fields based on the Order of declaration.
Consider an example, which illustrates the order of generation.
Ex: <’
type packet_kind_t: [Small, Medium, Large];
struct packet_s {
Kind: packet_kind_t;
Address: uint (bits: 32);
keep Kind = = Small => Address < 40; };
‘>
The above example explains that the packet_kind_t (kind) of enumerated type is generated first followed by address.The constraints definition says if the kind is Small in nature then generate address below 40.
Suppose, unknowingly if the address is declared first followed by Kind then the above constraint statement doesn’t hold good.
In order to achieve the same result, add an explicit generation order constraint supported by Specman Elite e-language.
The below example shows the constraints for such Operation.
Syntax:
keep soft gen (control- field) before (control –field);
Ex: <’
type packet_kind_t: [Small, Medium, Large];
struct packet_s {
Address: uint (bits: 32);
Kind: packet_kind_t;
keep Kind = = Small => Addr < 40;
keep soft gen (Kind) before (Address); };
‘>
Consider an example, which illustrates the order of generation.
Ex: <’
type packet_kind_t: [Small, Medium, Large];
struct packet_s {
Kind: packet_kind_t;
Address: uint (bits: 32);
keep Kind = = Small => Address < 40; };
‘>
The above example explains that the packet_kind_t (kind) of enumerated type is generated first followed by address.The constraints definition says if the kind is Small in nature then generate address below 40.
Suppose, unknowingly if the address is declared first followed by Kind then the above constraint statement doesn’t hold good.
In order to achieve the same result, add an explicit generation order constraint supported by Specman Elite e-language.
The below example shows the constraints for such Operation.
Syntax:
keep soft gen (control- field) before (control –field);
Ex: <’
type packet_kind_t: [Small, Medium, Large];
struct packet_s {
Address: uint (bits: 32);
Kind: packet_kind_t;
keep Kind = = Small => Addr < 40;
keep soft gen (Kind) before (Address); };
‘>
Tuesday, March 31, 2009
specman e-language supports constraint random generation
specman e-language supports the concept of constrained random generation.
. Constraints are applied on struct members e.g Fields and methods.
· Constraints are Boolean equations
· Constraints are declarative statements
Specman e-language categories the constrained mechansim as follows :
1) Random Generation without any constraints parameters
2) Directed Random constrained Generation [ e.g from .. to ]
3) Directed constrained Generation
For constraining a Field use the following syntax :
keep Boolean-expression
Ex: struct packet_s {
Length : uint(bits:6);
Address : uint(bits:2);
// application of Directed Constraints Parameter for Length field
keep Length = = 10;
// application of Directed Random Constraints Parameter for Address field
keep Address in [0..2];
};
For constraining elements in a list (array):
keep for each (item) in list_name {
Boolean-expression; };
Ex: Struct packet_driver_s {
Packets : list of packet_s;
// Constraints list for the individual fields
keep for each (pkt) in packets {
pkt.len < 10; }; };
The syntax for implication constraints are given below:
keep Boolean-expr1 => Boolean-expr2;
Ex:
keep size = = SHORT => length < 10;
keep size = = LONG => length > 20;
Or, suppose if we want to constraint using lists:
Ex:
keep for each (pkt) in packet {
index = = 0 => pkt.addr = = 1 and pkt.kind = = GOOD;
index = = 1 => pkt.addr = = 2 and pkt.kind = = BAD; };
Weighted Constraints:
Weighted constraints are used on a specific application. It allows selection weight for value or range of values. In order to achieve a weighted constraint we need to apply a soft control on the distribution of generated values.
syntax: keep soft gen-item = = select {weight: value ;};
Ex: <’
keep soft length = = select {
20:14;
25:10;
10:20; };
‘>
. Constraints are applied on struct members e.g Fields and methods.
· Constraints are Boolean equations
· Constraints are declarative statements
Specman e-language categories the constrained mechansim as follows :
1) Random Generation without any constraints parameters
2) Directed Random constrained Generation [ e.g from .. to ]
3) Directed constrained Generation
For constraining a Field use the following syntax :
keep Boolean-expression
Ex: struct packet_s {
Length : uint(bits:6);
Address : uint(bits:2);
// application of Directed Constraints Parameter for Length field
keep Length = = 10;
// application of Directed Random Constraints Parameter for Address field
keep Address in [0..2];
};
For constraining elements in a list (array):
keep for each (item) in list_name {
Boolean-expression; };
Ex: Struct packet_driver_s {
Packets : list of packet_s;
// Constraints list for the individual fields
keep for each (pkt) in packets {
pkt.len < 10; }; };
The syntax for implication constraints are given below:
keep Boolean-expr1 => Boolean-expr2;
Ex:
keep size = = SHORT => length < 10;
keep size = = LONG => length > 20;
Or, suppose if we want to constraint using lists:
Ex:
keep for each (pkt) in packet {
index = = 0 => pkt.addr = = 1 and pkt.kind = = GOOD;
index = = 1 => pkt.addr = = 2 and pkt.kind = = BAD; };
Weighted Constraints:
Weighted constraints are used on a specific application. It allows selection weight for value or range of values. In order to achieve a weighted constraint we need to apply a soft control on the distribution of generated values.
syntax: keep soft gen-item = = select {weight: value ;};
Ex: <’
keep soft length = = select {
20:14;
25:10;
10:20; };
‘>
Thursday, March 19, 2009
specman e-language usage examples for extending methods
Here i am listing examples of extending methods using specman e-language concept.
Ex : extending using is_also
---> Filename packet.e
<’
struct packet_s {
my_method () is {
out (“I am here”);
};
};
‘>
-------> new file packet_extend.e
<’
import packet.e;
extend packet_s {
my_method () is also {
out("to learn e-language”);
};
};
‘>
when we execute the packet_extend.e we can see finally the output appearing as "I am here to learn e-language".
Ex : extend using is first
---> Filename packet.e
<’
struct packet_s {
my_method () is {
out (“I am here”);
};
};
'>
---> New file : packet_extend.e
<’
import packet_extend.e;
extend packet_s {
my_method () is first {
out (“to learn e-language”);
};
};
'>
when we execute the packet_extend.e we can see finally the output appearing as "to learn e-language i am here".
Ex: extend using is only
---> Filename packet.e
<’
struct packet_s {
my_method () is {
out (“I am here”); }; };
'>
---> New file packet_extend.e
<’
import packet.e;
extend transaction_s {
my_method () is only {
out (“to learn e-language”);
};
};
'>
when we execute the packet_extend.e we can see finally the output appearing as "to learn e-language ", this extend method operator overrules the previous contents of the same method defined.
Ex : extending using is_also
---> Filename packet.e
<’
struct packet_s {
my_method () is {
out (“I am here”);
};
};
‘>
-------> new file packet_extend.e
<’
import packet.e;
extend packet_s {
my_method () is also {
out("to learn e-language”);
};
};
‘>
when we execute the packet_extend.e we can see finally the output appearing as "I am here to learn e-language".
Ex : extend using is first
---> Filename packet.e
<’
struct packet_s {
my_method () is {
out (“I am here”);
};
};
'>
---> New file : packet_extend.e
<’
import packet_extend.e;
extend packet_s {
my_method () is first {
out (“to learn e-language”);
};
};
'>
when we execute the packet_extend.e we can see finally the output appearing as "to learn e-language i am here".
Ex: extend using is only
---> Filename packet.e
<’
struct packet_s {
my_method () is {
out (“I am here”); }; };
'>
---> New file packet_extend.e
<’
import packet.e;
extend transaction_s {
my_method () is only {
out (“to learn e-language”);
};
};
'>
when we execute the packet_extend.e we can see finally the output appearing as "to learn e-language ", this extend method operator overrules the previous contents of the same method defined.
Subscribe to:
Comments (Atom)

 
 
