Download presentation
Presentation is loading. Please wait.
1
Washington University
CS/CoE 536 Reconfigurable System On Chip Design Lecture 4 : Demonstration of Machine Problem 1 : CAM-based Firewall Washington University Fall 2002 Chris Neely, Chris Zuver Copyright 2002
2
MP1 Packet Classification Hardware
103 CAM_MASK_1 103 CAM_VALUE_1 Drop 103 72 71 40 39 8 7 Src IP Dest IP Src Port Dest Port Proto 103 CAM_VALUE_2 103 CAM_MASK_2 match <= ‘1’ when (input = 0xFFFFFFFFFFFFFFFFFFFFFFFFFF”) else ‘0’;
3
Protocol Headers Cell Header IP Header UDP IP Header Payload PAD
AAL5 Trailer AAL5 Pad CPS-UU & CPI Frame Len AAL5 AAL5 Frame Checksum
4
Protocol Wrappers Timing Diagram
CLK Data A A I I I I I U U D D D D D - - A A D D D D D D D P P P F F - - Cell Level SOC Data A - I I I I I U U D D D D D - - - - D D D D D D D F F - - - - - DataEn IP Level Frame Level SOF EOF SOD A ATM Header I IP Header D Payload Data Data Enabled during frame trailer Only use these signals to process UDP/IP packets - Don't care U UDP Header P Padding F Frame Trailer This cycle is optional. It does not appear in simulation UDP payload starts 2 cycles after SOD signal. UDP payload ends with EOF signal.
5
State Transitions for Processing Packet
States correspond to order of data in the packet header. State transition are based on data_en=‘1’ idle ver flags ttl srcip_ttl_1 dstip_ttl_2 ports_ttl_3 checksum_ttl_4 xmit GIVEN FSM
6
CAM Update Datagram ATM Header Ver HL ToS Packet Len Fragment IP ID Special UDP/IP Datagram updates values of CAM Entries Allows software-controlled update of CAM registers Fields alocated for: CAM_VALUE_1 CAM_MASK_1 CAM_VALUE_2 CAM_MASK_2 Checksum Proto TTL Source IP address ( 0xC0A81E0D ) Src Port Dest Port ( 0x0320 ) Length Checksum (Reserved) # CAMs CAM_1_SRC_IP CAM_1_DEST_IP CAM_VALUE_1 CAM_1_PORTS (PAD) CAM_1_ PROTO CAM_MASK_1 CAM_MASK_1 CAM_2_SRC_IP CAM_2_DEST_IP CAM_VALUE_2 CAM_2_PORTS (PAD) CAM_2_ PROTO CAM_MASK_2 CAM_MASK_2 … (if necessary) AAL5 Pad CPS-UU & CPI Frame Len AAL5 Frame Checksum
7
State Transitions for updating CAMs
idle ver flags ttl srcip_ttl_1 dstip_ttl_2 ports_ttl_3 checksum_ttl_4 xmit GIVEN FSM control_ports_ttl_3 Data_flop = x”C0A80101” Data_flop(15..0) /= x”0320” control_checksum_ttl_4 control_ports_ttl3 control_cam_header control_cam1_src_entry control_cam1_dst_entry control_cam1_ports_entry control_cam1_proto_entry control_cam1_src_mask control_cam1_dst_mask control_cam1_ports_mask control_cam1_proto_mask control_cam2_src_entry control_cam2_dst_entry control_cam2_ports_entry control_cam2_proto_entry control_cam2_src_mask control_cam2_dst_mask control_cam2_ports_mask control_cam2_proto_mask eof_flop=‘1’ and den_flop=‘1’ eof_flop=‘0’ and den_flop=‘1’ State transition are based on data_en=‘1
8
FPX Hardware Design Flow
Compile circuit (vcom) Verify Functionality (vsim) Constrain Placement to FPX RAD Verify that that resulting packets have correct TTL Test Module with actual traffic input Synthesize Logic to Xilinx gate technology (Synplicity) Upload bitfile To FPX for testing Place and Route with constraints (Xilinx) Verify Post Place & Route Timing (ModelSim) Generate bitstream (Xilinx)
9
Accessing FPGA Design Tools in Sever 201
Opening Cygwin, ModelSim, and Synplicity Start Menu --> Engineering --> FPGA Tools
10
Downloading and extracting MP1 files
Download the MP1 tar file from the website. Save the file under your CEC home directory (e.g. H:\cs536\mp1) Extract the files from Cygwin: tar xvfz FireWall.tar.gz
11
VHDL EDITORS EMACS VI ModelSim Synplicity OTHER ………..
emacs /vhdl/wrapper_app.vhd & Good for beginners VI vi /vhdl/wrapper_app.vhd ModelSim Click open.. Browse to /vhdl/wrapper_app.vhd Synplicity Open wrapper_app.vhd OTHER ………..
12
Compiling the design Compiling the tools Simulating the Design
cd H:\cs536\mp1\FireWall make compile Simulating the Design make sim (It may take a couple minutes to load the simulation.)
13
ModelSim Simulation ModelSim Workspace Run simulation Open windows
ModelSim’s Status (ex. Loading…) View simulation waveforms Select entity Select signals Force values
14
ModelSim Simulation [continued]
Incoming packet Zooming in on waveforms Custom Zoom Zoom Full Outgoing packet
15
ModelSim Simulation [continued]
Transmitted Packet TTL Src IP Dest IP TTL ≠ 0 Src IP
16
Editing wrapper_app.vhd
From cygwin Emacs /sim/wrapper_app.vhd From Emacs Scroll to the Signal Process Line 248 Change the null assignment for state dstip_ttl_2 to assign data_buf2(31 downto 24) to zero. This sets TTL to zero. Exact code is shown in diagram.
17
ModelSim Simulation [continued]
Dropped Packet TTL Src IP Dest IP TTL = 0 Src IP
18
Testbench Data Sample format of input data file (/sim/INPUT_CELLS.DAT)
Compared to output data file (/sim/LC_CELLSOUT.DAT) Transmitted Packet Dropped Packet
19
Synthesizing the Design (Synplicity)
Listing of the synthesizable vhdl files in the design. The files are listed in bottom-up order Open the project file: /syn/wrapper_app.prj Wrapper_app.ssr Error/Warnings log with estimated timing information Target FPGA Xilinx Virtex-E XCV2000E -7 FG680
20
Synthesizing the Design [continued]
Synplicity from the Cygwin console make syn Quick method Poor feedback: must open wrapper_app.srr to view details.
21
Backend Tools : Generating the Bitstream
Xilinx Tools make build Build Script (/syn/rad-xcv2000e/build) #!/bin/bash part=xcv2000e-7-fg680 #defines the target device design=wrapper_app #defines the design name used in Synplicity ngdbuild -p ${part} ${design} -uc fpx.ucf #Parses netlist into logical description map -p ${part} -o top.ncd ${design}.ngd ${design}.pcf #Maps description into components par -w -ol 2 top.ncd ${design}.ncd ${design}.pcf #Connects and positions components trce ${design}.ncd ${design}.pcf -e 2 -o ${design}.twr #Generates a timing report bitgen ${design}.ncd -b -l -w -f bitgen.ut #Creates the bitstream to program the FPGA More information about these tools is available in the CEC under: P:\Xilinx42\doc\usenglish\docs\dev
22
Testing the design on the FPX
NCHARGE website for automated testing: Username Cs536 Password soc_firewall
23
Testing the design on the FPX
Click TEST BIT FILE Enter Class ID (5 digit) Enter MP1 Click Create Entry Locate empty file in list of files. Click Upload next to file Click Browse and select /syn/rad-scv2000e/wrapper_app.bit
24
Verifying the Results After uploading your bitfile the website will automatically load your design into an FPX, create traffic, send the traffic, and return a results file showing the tests. To view results (this may take several minutes to appear after uploading) click on the results link under “TEST BIT FILE.”
25
Creating the waveforms
Generating postscript files from ModelSim Adjust ModelSim wave window such that all important information needed to verify your results are visible (a.k.a zoom in enough to see data values, etc) From the file menu select Print Postscript…\ Specify the filename and select “current view” for both signals and time range.
26
Creating the waveforms (cont.)
Converting postscript files to PDF format from Cygwin. ps2pdf input.ps > output.pdf If your .ps file will not display using Ghostview then try this command to fix the errors. ps2ps input.ps output.ps
27
Uploading your solutions
Open the page
Similar presentations
© 2025 SlidePlayer.com. Inc.
All rights reserved.