Lecture 6 - Writing Tests - PowerPoint PPT Presentation

1 / 36
About This Presentation
Title:

Lecture 6 - Writing Tests

Description:

Lecture 6 - Writing Tests A difference if treating the design as a black box or if you have access to internal signals EE762 assignment testbenches treat student ... – PowerPoint PPT presentation

Number of Views:106
Avg rating:3.0/5.0
Slides: 37
Provided by: Joann246
Category:

less

Transcript and Presenter's Notes

Title: Lecture 6 - Writing Tests


1
Lecture 6 - Writing Tests
  • A difference if treating the design as a black
    box or if you have access to internal signals
  • EE762 assignment testbenches treat student design
    as a black box
  • Must know what you are testing
  • Must test corner cases

2
Floating Point Multiplier
  • Used as a EE762 assignment

Project Assignment 10 Floating Pt Unit DUE Mon
Mar 10   In this assignment you will use VHDL to
describe the function of a floating point
multiplier. The multiplier will accept IEEE
Standard 754 single precision inputs and produce
single precision output. It will support NaN,
8, 0, normalized numbers, and denormalized
numbers.   The interface to the design will be
3
The Assignment
Inputs will arrive as per the attached
specification and test bench. Your design will
latch inputs using the latch input signal. Your
design will drive the outputs using the drive
signal. After driving the output, when the drive
signal again goes high, you must drive the bus
back to high impedance. Use the component
interface given in the testbench STEP 1) Write
the initial architecture. In the initial
architecture, simply latch the input, route the A
input to the output, and correctly drive the C
bus. If you get this step working correctly the
rest will go much easier. SIMULATE   STEP 2)
Write a VHDL process to do the floating point
multiply.   Recommendation As you start to
write your routine handle special cases first.
Write the code to handle the NaNs - then simulate
and check that you handle the NaNs correctly.
Note that 8 0 results in a NaN.. Then
correctly handle 8, and verify through
simulation. Then correctly handle 0 and
simulate. Finally do the cases where you
actually have to multiply.   You can use
process(es), concurrent signal assignment, etc.,
as you would like. You will find the following
files in degroat/ee762_assign   fpmtb.vhdl -
the test bench - the component declaration,
configuration,and instantiation have been done
but you can change them if you want
to.   fpmvectors - a list of the input stimul
4
The Assignment (2)
fpm.do - do file for listing and
waveform   Other NOTES for floating point
multiplier.   The test bench also uses a
concurrent procedure call that reads the
testvector file in degroat/ee762_assign/fpmvecto
rs. Use of these vectors is hard coded in the
concurrent procedure as are the checks and
grading routine. This procedure has been
compiled and is in the library assign in this
directory. To provide the mapping to it you must
execute the unix command   qhmap assign
/user2/faculty/degroat/ee762_assign/assign   This
provides the logical mapping such that the
library clause in the test bench know where
library assign is located. This must be done
prior to compiling the test bench. The procedure
will also do the grading of this assignment.
5
Floating Point Standard
Single Precision Floating Point Format Value
is If e 255 and f ? 0, then v is NaN
regardless of s If e 255 and f 0, then v
(-1)s 8 If 0 lt e lt 255, then v (-1)s
2e-127 (1.f) If e 0 and f ? 0, then v
(-1)s 2-126 (x.f) (denormalized
numbers)(x is msb of value stored) If e 0 and
f 0, then v (-1)s 0 (zero)
6
Other Specifications
  • Inputs are in IEEE 754 Single Precision
  • Results are in IEEE 754 Single Precision Format
  • Unit can latch A and B inputs from parallel
    busses
  • Must be able to handle both numerical values and
    special cases
  • NaNs, inif,
  • zero,
  • normalized numbers, denormalized numbers

7
What to Check
  • How to test the floating point multiplier for
    both timing of inputs and outputs and functional
    operation?
  • Assume you have no knowledge of how design is
    going to be implemented
  • But you still know the specifications that it
    must adhere to.

8
The Test Vectors
Must test for normal operation and boundary
conditions  IN GENERAL THE CLASS OF INPUTS
ARE A input by B input NaN NaN 8 8 0 0
Denorm Denorm Norm Norm   Denorm
OtherVal Max Denorm Denorm OtherVal Min
Norm Rounding using first guard
bit Rounding using 1st and 2nd guart bits
9
The Inputs Example 1
...NaN 01111111100000000000000000000001...NaN
01111111100000000000000000000001...Nan
01111111100000000000000000000001...NaN
01111111100000000000000000000001.INIF
01111111100000000000000000000000...Nan
01111111100000000000000000000001...NaN
01111111100000000000000000000001.-INIF
11111111100000000000000000000000...Nan
01111111100000000000000000000001...NaN
01111111100000000000000000000001....0
00000000000000000000000000000000...Nan
01111111100000000000000000000001...NaN
01111111100000000000000000000001....-0
10000000000000000000000000000000...Nan
01111111100000000000000000000001...NaN
01111111100000000000000000000001....1
00111111100000000000000000000000...Nan
01111111100000000000000000000001...NaN
01111111100000000000000000000001....-1
10111111100000000000000000000000...Nan
01111111100000000000000000000001...NaN
01111111100000000000000000000001...25
01000001110010000000000000000000...Nan
01111111100000000000000000000001...NaN
01111111100000000000000000000001...-25
11000001110010000000000000000000...Nan
01111111100000000000000000000001...NaN
01111111100000000000000000000001..100
01000010110010000000000000000000...Nan
01111111100000000000000000000001...NaN
01111111100000000000000000000001.1/100
00111100001000111101011100001010...Nan
01111111100000000000000000000001...NaN
01111111100000000000000000000001DNORM
00000000001010000000000000000000...Nan
01111111100000000000000000000001...NaN
01111111100000000000000000000001-DNORM
10000000001010000000000000000000...Nan
01111111100000000000000000000001.INIF
01111111100000000000000000000000...NaN
01111111100000000000000000000001...NaN
01111111100000000000000000000001
10
The Inputs Example 2
...25 01000001110010000000000000000000....0
00000000000000000000000000000000....0
00000000000000000000000000000000...25
01000001110010000000000000000000....-0
10000000000000000000000000000000....-0
10000000000000000000000000000000...25
01000001110010000000000000000000....1
00111111100000000000000000000000...25
01000001110010000000000000000000...25
01000001110010000000000000000000....-1
10111111100000000000000000000000...-25
11000001110010000000000000000000...25
01000001110010000000000000000000...25
01000001110010000000000000000000..625
01000100000111000100000000000000...25
01000001110010000000000000000000...-25
11000001110010000000000000000000..-625
11000100000111000100000000000000...25
01000001110010000000000000000000..100
01000010110010000000000000000000.2500
01000101000111000100000000000000...25
01000001110010000000000000000000.1/100
00111100001000111101011100001010.0.25
00111110011111111111111111111111...25
01000001110010000000000000000000DNORM
00000000001010000000000000000000small1
00000001111110100000000000000000...25
01000001110010000000000000000000-DNORM
10000000001010000000000000000000small2
10000001111110100000000000000000...-25
11000001110010000000000000000000...NaN
01111111100000000000000000000001...NaN
01111111100000000000000000000001...-25
11000001110010000000000000000000.INIF
01111111100000000000000000000000.-INIF
11111111100000000000000000000000...-25
11000001110010000000000000000000.-INIF
11111111100000000000000000000000.INIF
01111111100000000000000000000000...-25
11000001110010000000000000000000....0
00000000000000000000000000000000....-0
10000000000000000000000000000000
11
Applying Inputs to Design
WHILE (NOT ENDFILE(test_data)) LOOP --get
next input test vector and expected result
readline(test_data,cur_line)
read(cur_line,aid) read(cur_line,a_test_val)
read(cur_line,bid) read(cur_line,b_test_val)
readline(test_data,cur_line)
read(cur_line,resid)read(cur_line,result_val)
std_result_val To_StdLogicVector(result_val)
num_tests num_tests 1 -- run
through bus cycle to send data to unit
aid_sig lt "", aid after 20 ns
bid_sig lt "", bid after 20 ns
resid_sig lt "", resid after 20 ns --
drive signals on bus aval lt
To_StdLogicVector(a_test_val) after 20 ns, HIGHZ
after 80 ns bval lt To_StdLogicVector(b_test_
val) after 20 ns, HIGHZ after 80 ns latch lt
'0' after 20 ns, '1' after 70 ns wait for
100 ns drive lt '0' after 20 ns, '1' after
80 ns exp_res lt std_result_val after 20 ns,
HIGHZ after 80 ns wait for 50 ns ASSERT
(C std_result_val) REPORT "result does
not agree with expected result" SEVERITY
WARNING IF (C / std_result_val) THEN
num_errors num_errors 1 err_sig lt
'1', '0' after 10 ns END IF wait for 50
ns END LOOP
Inputs are read from a file and applied to the
design
12
The File I/O Declarations
  • First must set up the basic declarations

13
File I/O
  • And then must also do the declarations for File
    I/O
  • Note that the file I/O here uses the 1987 version
    of the language

14
Text IO after 87
  • The declaration of the file is the only real
    change from the 87 standard
  • Now
  • FILE file_name TEXT OPEN read_mode IS
  • the_file_system_file_n
    ame
  • VARIABLE cur_line LINE
  • VARIABLE addr bit_vector (15 downto 0)
  • VARIABLE data bit_vector (7 downto 0)
  • In the code
  • WHILE (NOT ENDFILE(file_name)) LOOP
  • READLINE (file_name,curline)
  • READ (curline, addr)
  • READ (curline, data)
  • saddr lt addr
  • sdata lt data
  • END LOOP

15
Checking Results
  • Timing is checked when result is expected on bus
    and again just prior to bus going back to high
    impedance.
  • Busses are also checked that they go back to a
    value of high impedance
  • When results do not match what is expected a
    signal called error goes to 1 for 10 ns

16
Use of TEXT IO
  • The TEXT IO procedures and functions are in
    PACKAGE TEXTIO within LIBRARY STD.
  • So any design entity that wants to do IO using
    these routines must have a
  • USE STD.TEXTIO.ALL
  • You will find a reference in Navabi, pg 603,604.

17
TEXT IO Philosophy
  • The general input/output philosophy of VHDL is
    one of line orientated operation.
  • For Input you first read the entire line up until
    ltcrgtltlfgt
  • Same for output
  • Then you read the elements off the line.
  • For the file here the elements were
  • AID A_FP_NUM BID B_FP_NUM

18
Type that can be read/written using TEXT I/O
  • The data types for which support is present
  • Strings
  • Bit
  • Bit_vector
  • Integer
  • Real

19
Example 1
  • use std.textio.all
  • ENTITY textiotest IS
  • END textiotest
  •  
  • ARCHITECTURE first OF textiotest IS
  •  
  • FILE test_vecs TEXT is "fpmvectors"
  • SIGNAL a,b bit_vector(31 downto 0)
  • signal aid,bid string(1 to 6)

20
Example 1 (cont)
  • BEGIN --of architecture
  •  
  • PROCESS
  • VARIABLE cur_line LINE
  • VARIABLE aidv,bidv string(1 to 6)
  • VARIABLE av,bv bit_vector(31 downto 0)
  • BEGIN
  • FOR I in 1 to 10 LOOP
  • READLINE (test_vecs, cur_line)
  • READ (cur_line,aidv)
  • aid lt aidv
  • READ (cur_line,av)
  • a lt av
  • READ (cur_line,bidv)
  • bid lt bidv
  • READ (cur_line,bv)
  • b lt bv
  • WAIT FOR 100 ns

21
Example 2
  • use std.textio.all
  • ENTITY textiotest2 IS
  • END textiotest2
  •  
  • ARCHITECTURE first OF textiotest2 IS
  • FILE test_vecs TEXT is "fpmvectors"
  • SIGNAL a,b,r bit_vector(31 downto 0)
  • signal aid,bid,rid string(1 to 6)
  • BEGIN

22
Example 2 (cont)
  • PROCESS
  • VARIABLE cur_line LINE
  • VARIABLE aidv,bidv,ridv string(1 to 6)
  • VARIABLE av,bv,rv bit_vector(31 downto
    0)
  • BEGIN
  • WHILE (NOT ENDFILE(test_vecs)) LOOP
  • READLINE (test_vecs, cur_line)
  • READ (cur_line,aidv)
  • aid lt aidv
  • READ (cur_line,av)
  • a lt av
  • READ (cur_line,bidv)
  • bid lt bidv
  • READ (cur_line,bv)
  • b lt bv
  • READLINE (test_vecs, cur_line)
  • READ (cur_line,ridv)
  • rid lt ridv

23
Test transactions are in file
  • Locating you test transactions in a file allows
    for easy addition to the test file as you
    progress through the verification plan
  • Allows you to incorporate new tests easily based
    on the results to date.
  • Opens the possibility for very advanced methods
  • Itterative application of tests and test
    generation.
  • New tests may be generated given the response to
    a set test.

24
Text IO Output
  • During execution text IO can also write output to
    file open for output.
  • An example of that is in testread.vhdl

25
Another example
  • HDL code that uses TEXTIO to generate an HDL code
    file.
  • ENTITY codegen8 IS
  • END codegen8
  •  
  • USE STD.TEXTIO.all
  • ARCHITECTURE one OF codegen8 IS
  •  
  • BEGIN
  • --Process to automatically generate the dual
    Gray Code counter descriptions
  • -- for an 8 bit counter. It is based on the
    code for generation of the
  • -- 6 bit dual Gray Code counter with slight
    modification to the loop indexes.
  • -- This code is somewhat shorter than the
    code produced in the output file

26
The code - Declarations
  • PROCESS
  • --declare file
  • FILE cnt8file TEXT OPEN write_mode IS
    "cnt8.vhdl"
  • VARIABLE cur_line LINE
  • VARIABLE mytext STRING (1 to 40)
  • VARIABLE mytext80 STRING (1 to 65)
  • --TYPE cntvectype IS ARRAY(7 downto 0) of
    bit
  • TYPE graycodetype IS ARRAY (0 to 255) OF
    bit_vector(7 downto 0)
  • VARIABLE graycode graycodetype
  • VARIABLE l1t1 STRING (1 to 12) "
    WHEN ("""
  • VARIABLE l1t2 STRING (1 to 5) """) gt"
  • VARIABLE l2t1 STRING (1 to 22) "
    next_state lt """
  • VARIABLE l2t2 STRING (1 to 2) """"
  • VARIABLE blankline STRING (1 to 5) "
    "
  • VARIABLE dl2t1 STRING (1 to 23) "
    dnext_state lt """

27
Generate 8-bit Gray Code
  • BEGIN
  • --generate up to 8 bit GRAY CODE
  • graycode(0) "00000000"
  • graycode(1) "00000001"
  • FOR i IN 0 to 1 LOOP --2 bit code - 4 entries
  • graycode(i2) graycode(1-i)
  • graycode(i2) graycode(i2)(7 downto 2)
    "1" graycode(i2)(0)
  • END LOOP
  • FOR i IN 0 to 3 LOOP --3 bit code - 8 entries
  • graycode(i4) graycode(3-i)
  • graycode(i4) graycode(i4)(7 downto 3)
    "1" graycode(i4)(1 downto 0)
  • END LOOP
  • FOR i IN 0 to 7 LOOP --4 bit code - 16
    entries
  • graycode(i8) graycode(7-i)
  • graycode(i8) graycode(i8)(7 downto 4)
    "1" graycode(i8)(2 downto 0)
  • END LOOP

28
The Gray Code 5 to 8 bit
  • FOR i IN 0 to 15 LOOP --5 bit code - 32 entries
  • graycode(i16) graycode(15-i)
  • graycode(i16) graycode(i16)(7 downto
    5) "1" graycode(i16)(3 downto 0)
  • END LOOP
  • FOR i IN 0 to 31 LOOP --6 bit code - 64
    entries
  • graycode(i32) graycode(31-i)
  • graycode(i32) graycode(i32)(7 downto
    6) "1" graycode(i32)(4 downto 0)
  • END LOOP
  • FOR i IN 0 to 63 LOOP --7 bit code - 128
    entries
  • graycode(i64) graycode(63-i)
  • graycode(i64) graycode(i64)(7) "1"
    graycode(i64)(5 downto 0)
  • END LOOP
  • FOR i IN 0 to 127 LOOP --8 bit code - 256
    entries
  • graycode(i128) graycode(127-i)
  • graycode(i128) "1" graycode(i128)(6
    downto 0)
  • END LOOP

29
Text I/O output the state machine
  • mytext "ENTITY cnt8 IS
    "
  • WRITE (cur_line,mytext)
  • WRITELINE (cnt8file,cur_line)
  • mytext " PORT(clk IN bit
    "
  • WRITE (cur_line,mytext)
  • WRITELINE (cnt8file,cur_line)
  • mytext " cnt OUT bit_vector(7
    downto 0) "
  • WRITE (cur_line,mytext)
  • WRITELINE (cnt8file,cur_line)
  • mytext " dcnt OUT bit_vector(7
    downto 0) "
  • WRITE (cur_line,mytext)
  • WRITELINE (cnt8file,cur_line)
  • mytext " err OUT bit)
    "
  • WRITE (cur_line,mytext)
  • WRITELINE (cnt8file,cur_line)
  • mytext "END cnt8
    "
  • WRITE (cur_line,mytext)
  • WRITELINE (cnt8file,cur_line)
  • mytext "
    "

30
Start output of the architecture
  • mytext "ARCHITECTURE one OF cnt8 IS
    "
  • WRITE (cur_line,mytext)
  • WRITELINE (cnt8file,cur_line)
  • mytext80 " SIGNAL state,next_state
    bit_vector(7 downto 0) ""00000000"""
  • WRITE (cur_line,mytext80)
  • WRITELINE (cnt8file,cur_line)
  • mytext80 " SIGNAL dstate,dnext_state
    bit_vector(7 downto 0)""11111111"""
  • WRITE (cur_line,mytext80)
  • WRITELINE (cnt8file,cur_line)
  • mytext "BEGIN
    "
  • WRITE (cur_line,mytext)
  • WRITELINE (cnt8file,cur_line)

31
The F/F Process
  • --now output the process for the latching of
    state
  • --
  • mytext " --Latching logic specification
    "
  • WRITE (cur_line,mytext)
  • WRITELINE (cnt8file,cur_line)
  • mytext " PROCESS
    "
  • WRITE (cur_line,mytext)
  • WRITELINE (cnt8file,cur_line)
  • mytext " BEGIN
    "
  • WRITE (cur_line,mytext)
  • WRITELINE (cnt8file,cur_line)
  • mytext " WAIT UNTIL clk'1' AND
    clk'event "
  • WRITE (cur_line,mytext)
  • WRITELINE (cnt8file,cur_line)
  • mytext " state lt next_state
    "
  • WRITE (cur_line,mytext)
  • WRITELINE (cnt8file,cur_line)
  • mytext " dstate lt dnext_state
    "
  • WRITE (cur_line,mytext)

32
To close the output file.
  • At the end, after done with all code to output
    need to close the output file. WAIT stops
    execution of the PROCESS.
  • mytext "END one
    "
  • WRITE (cur_line,mytext)
  • WRITELINE (cnt8file,cur_line)
  • FILE_CLOSE(cnt8file)
  • WAIT
  • END PROCESS
  • END one --end the architecture.

33
More TEXTIO example code
  • use std.textio.all
  • ENTITY textiotest IS
  • END textiotest
  •  
  • ARCHITECTURE first OF textiotest IS
  •  
  • FILE test_vecs TEXT is "fpmvectors"
  • SIGNAL a,b bit_vector(31 downto 0)
  • signal aid,bid string(1 to 6)

34
Continued
  • BEGIN --of architecture 
  • PROCESS
  • VARIABLE cur_line LINE
  • VARIABLE aidv,bidv string(1 to 6)
  • VARIABLE av,bv bit_vector(31 downto 0)
  • BEGIN
  • FOR I in 1 to 10 LOOP
  • READLINE (test_vecs, cur_line)
  • READ (cur_line,aidv)
  • aid lt aidv
  • READ (cur_line,av)
  • a lt av
  • READ (cur_line,bidv)
  • bid lt bidv
  • READ (cur_line,bv)
  • b lt bv
  • WAIT FOR 100 ns
  • END LOOP
  • WAIT

35
One more time
  • use std.textio.all
  • ENTITY textiotest2 IS
  • END textiotest2
  •  
  • ARCHITECTURE first OF textiotest2 IS
  • FILE test_vecs TEXT is "fpmvectors"
  • SIGNAL a,b,r bit_vector(31 downto 0)
  • signal aid,bid,rid string(1 to 6)
  • BEGIN
  • PROCESS
  • VARIABLE cur_line LINE
  • VARIABLE aidv,bidv,ridv string(1 to 6)
  • VARIABLE av,bv,rv bit_vector(31 downto
    0)

36
and
  • BEGIN
  • WHILE (NOT ENDFILE(test_vecs)) LOOP
  • READLINE (test_vecs, cur_line)
  • READ (cur_line,aidv)
  • aid lt aidv
  • READ (cur_line,av)
  • a lt av
  • READ (cur_line,bidv)
  • bid lt bidv
  • READ (cur_line,bv)
  • b lt bv
  • READLINE (test_vecs, cur_line)
  • READ (cur_line,ridv)
  • rid lt ridv
  • READ (cur_line,rv)
  • r lt rv
  • WAIT FOR 100 ns
  • END LOOP
  • WAIT
Write a Comment
User Comments (0)
About PowerShow.com