George Mason University ECE 448 – FPGA and ASIC Design with VHDL VGA Display Part 2 Animation ECE 448 Lecture 9.

Slides:



Advertisements
Similar presentations
VHDL Lecture 1 Megan Peck EECS 443 Spring 08.
Advertisements

1 VLSI DESIGN USING VHDL Part II A workshop by Dr. Junaid Ahmed Zubairi.
Ring Counter Discussion D5.3 Example 32. Ring Counter if rising_edge(CLK) then for i in 0 to 2 loop s(i)
Sequential-Circuit Building Blocks
George Mason University ECE 448 – FPGA and ASIC Design with VHDL ECE 448 Lecture 10 Advanced Testbenches.
Counters Discussion D5.3 Example 33. Counters 3-Bit, Divide-by-8 Counter 3-Bit Behavioral Counter in Verilog Modulo-5 Counter An N-Bit Counter.
Algorithmic State Machine (ASM) Charts
George Mason University ECE 448 – FPGA and ASIC Design with VHDL Finite State Machines State Diagrams, State Tables, Algorithmic State Machine (ASM) Charts,
ECE 448 Lecture 3 Combinational-Circuit Building Blocks Data Flow Modeling of Combinational Logic ECE 448 – FPGA and ASIC Design with VHDL.
ECE 448 Lecture 7 VGA Display Part 1
Simple Testbenches Behavioral Modeling of Combinational Logic
ECE 448 – FPGA and ASIC Design with VHDL Lecture 15 External SRAM.
ECE 545 Lecture 7 Behavioral Modeling of Sequential-Circuit Building Blocks Mixing Design Styles Modeling of Circuits with a Regular Structure.
1 Part V: VHDL CODING. 2 Design StructureData TypesOperators and AttributesConcurrent DesignSequential DesignSignals and VariablesState Machines A VHDL.
Owais Ibrahim Akram Mohsin Murad. ONE OF THE BASIC ATTARI GAMES. THE PONG GAME CONSISTS OF A BALL RANDOMLY BOUNCING ON THE SCREEN. A PADDLE AT THE BASE.
George Mason University FPGA Memories ECE 448 Lecture 13.
ECE 448: Lab 6 VGA Display (mini chess game). Video Graphic Array (VGA) Resolution: 640x480 Display: 16 colors (4 bits), 256 colors (8 bits) Refresh Rate:
Introduction to Experiment 5 VGA Signal Generator ECE 448 Spring 2009.
ECE 448 Lecture 8 VGA Display Part 2
George Mason University ECE 448 – FPGA and ASIC Design with VHDL VGA Display Part 1 VGA Synchronization ECE 448 Lecture 9.
Introduction to VGA 數位電路實驗 TA: 吳柏辰 Author: Trumen.
Finite State Machines VHDL ET062G & ET063G Lecture 6 Najeem Lawal 2012.
VHDL in 1h Martin Schöberl. AK: JVMHWVHDL2 VHDL /= C, Java,… Think in hardware All constructs run concurrent Different from software programming Forget.
ECE FPGA Microprocessor Design Erik Lee, Edward Jones, Emily Kan.
George Mason University ECE 545 Lecture 7 Advanced Testbenches.
ECE 448: Lab 4 VGA Display Mini-Pacman. Flexibility in the Second Part of the Semester Lab 4: VGA display (2 weeks) – 8 points Lab 5: Computer Graphics.
ECE 448: Lab 4 VGA Display. Bouncing Ball.. Organization and Grading.
Computer Engineering 4OI4 Project Proposal James Gurunlian Clarence Ngai
ECE 448: Lab 5 VGA Display. Breaking-Bricks..
George Mason University Simple Testbenches ECE 545 Lecture 4.
Figure 10.1 Color CRT and Phosphor Dots on Face of Display.
1 RAM. 2 PS2_Keyboard: entity work.Keyboard generic map (AddressBits => ADDRESSLENGTH) port map (Reset => Reset, Clock => ClockVGA, PS2Clock => PS2Clock,
Copyright (c) 2003 by Valery Sklyarov and Iouliia Skliarova: DETUA, IEETA, Aveiro University, Portugal.
VHDL Discussion Sequential Sytems. Memory Elements. Registers. Counters IAY 0600 Digital Systems Design Alexander Sudnitson Tallinn University of Technology.
 Seattle Pacific University EE Logic System DesignCounters-1 Shift Registers DQ clk DQ DQ ShiftIn Q3Q3 Q2Q2 DQ Q1Q1 Q0Q0 A shift register shifts.
ECE 448: Lab 4 VGA Display The Frogger. Flexibility in the Second Part of the Semester Lab 4: VGA display (2 weeks) – 8 points Lab 5: Computer Graphics.
Data Storage VHDL ET062G & ET063G Lecture 4 Najeem Lawal 2012.
George Mason University Controllers for Keccak_F and AES ECE 545 Lecture 11 Addendum.
George Mason University ECE 448 – FPGA and ASIC Design with VHDL VGA Display Part 3 Animation ECE 448 Lecture 11.
Algorithmic State Machines Sorting Signed & Unsigned Data Types
George Mason University ECE 448 – FPGA and ASIC Design with VHDL VGA Display Part 1 Synchronization & Pixel Generation ECE 448 Lecture 8.
George Mason University Behavioral Modeling of Sequential-Circuit Building Blocks ECE 545 Lecture 8.
Lecture 11 Xilinx FPGA Memories Part 2
George Mason University Advanced Testbenches Lecture 4.
ECE 448: Lab 4 VGA Display Snake Game. Flexibility in the Second Part of the Semester Lab 4: VGA display (2 weeks) – 8 points Lab 5: Computer Graphics.
George Mason University ECE 448 – FPGA and ASIC Design with VHDL VGA Display Part 3 Animation ECE 448 Lecture 11.
George Mason University ECE 448 – FPGA and ASIC Design with VHDL VGA Display Part 5 The Complete Pong Game ECE 448 Lecture 13.
Implementation of Pong over VGA on the Nexys 4 FPGA
Algorithmic State Machine (ASM) Charts: VHDL Code & Timing Diagrams
VGA Display Part 1 VGA Synchronization
Lecture L5.1 Mealy and Moore Machines
VGA Display Part 2 Pixel Generation
VGA Display Part 3 Text Generation
RTL Design Methodology
VGA Display Part 4 Text Generation
VGA Display Part 3 Animation
VGA Display Part 5 The Complete Pong Game
Sequential-Circuit Building Blocks
Algorithmic State Machine (ASM) Charts: VHDL Code & Timing Diagrams
Non-synthesizable VHDL Poor Design Practices
ECE 448 Lecture 13 Multipliers Timing Parameters
Fibonacci Sequence Lecture L4.1 Lab 3.
Behavioral Modeling of Sequential-Circuit Building Blocks
Sequntial-Circuit Building Blocks
FPro Video Subsystem: VGA Frame Buffer Core
ECE 448 Lecture 6 Finite State Machines State Diagrams, State Tables, Algorithmic State Machine (ASM) Charts, and VHDL code ECE 448 – FPGA and ASIC Design.
VGA Display: VGA Synchronization & Pixel Generation
Sequntial-Circuit Building Blocks
디 지 털 시 스 템 설 계 UP2 Kit를 이용한 카운터 설계
(Sequential-Circuit Building Blocks)
Presentation transcript:

George Mason University ECE 448 – FPGA and ASIC Design with VHDL VGA Display Part 2 Animation ECE 448 Lecture 9

2ECE 448 – FPGA and ASIC Design with VHDL Required Reading P. Chu, FPGA Prototyping by VHDL Examples Chapter 12, VGA Controller I: Graphic Chapter 13, VGA Controller II: Text Source Codes of Examples Nexys3 Reference Manual VGA Port, pages 15-17

3ECE 448 – FPGA and ASIC Design with VHDL Animation

4 Animation Basics ECE 448 – FPGA and ASIC Design with VHDL Animation is achieved by an object changing its location gradually in each frame We use signals, instead of constants, to determine boundaries of an object VGA monitor is refreshed 60 times per second The boundary signals need to be updated at this rate We create a 60 Hz enable tick, refr_tick, which is asserted for 1 clock cycle every 1/60 th of a second

5 Moving the Bar (Paddle) ECE 448 – FPGA and ASIC Design with VHDL 600 ≤ x ≤ 603 bar_y_t ≤ y ≤ bar_y_b bar_y_t = bar_y_reg bar_y_b=bar_y_t+BAR_Y _SIZE-1 BAR_V is a velocity of the bar (#pixels/frame)

6ECE 448 – FPGA and ASIC Design with VHDL -- bar left, right boundary constant BAR_X_L: integer:=600; constant BAR_X_R: integer:=603; -- bar top, bottom boundary signal bar_y_t, bar_y_b: unsigned(9 downto 0); constant BAR_Y_SIZE: integer:=72; -- reg to track top boundary (x position is fixed) signal bar_y_reg, bar_y_next: unsigned(9 downto 0); -- bar moving velocity when the button is pressed constant BAR_V: integer:=4; Moving the Bar in VHDL (1)

7ECE 448 – FPGA and ASIC Design with VHDL -- boundary bar_y_t <= bar_y_reg; bar_y_b <= bar_y_t + BAR_Y_SIZE - 1; -- pixel within bar bar_on <= '1' when (BAR_X_L<=pix_x) and (pix_x<=BAR_X_R) and (bar_y_t<=pix_y) and (pix_y<=bar_y_b) else '0'; -- bar rgb output bar_rgb <= "010"; --green Moving the Bar in VHDL (2)

8ECE 448 – FPGA and ASIC Design with VHDL -- new bar y-position process(bar_y_reg, bar_y_b, bar_y_t, refr_tick, btn) begin bar_y_next <= bar_y_reg; -- no move if refr_tick='1' then if btn(1)='1' and bar_y_b < (MAX_Y-1-BAR_V) then bar_y_next <= bar_y_reg + BAR_V; -- move down elsif btn(0)='1' and bar_y_t > BAR_V then bar_y_next <= bar_y_reg - BAR_V; -- move up end if; end process; Moving the Bar in VHDL (3)

9ECE 448 – FPGA and ASIC Design with VHDL process (clk, reset) begin if reset='1' then bar_y_reg '0'); elsif (clk'event and clk='1') then bar_y_reg <= bar_y_next; end if; end process; Moving the Bar in VHDL (4)

10 Moving the Ball ECE 448 – FPGA and ASIC Design with VHDL ball_x_l ≤ x ≤ ball_x_r ball_y_t ≤ y ≤ ball_y_b ball_x_l = ball_x_reg ball_x_r=ball_x_l+BALL_ SIZE-1 ball_y_t = ball_y_reg ball_y_b=ball_y_t+BALL_ SIZE-1

11 Ball Velocity ECE 448 – FPGA and ASIC Design with VHDL The ball may change direction by hitting the wall, the paddle, or the bottom or top of the screen We decompose velocity into an x-component and a y-component Each component can have either a positive value BALL_V_P or a negative value BALL_V_N The current value of each component is kept in x_delta_reg and y_delta_reg

12ECE 448 – FPGA and ASIC Design with VHDL constant BALL_SIZE: integer:=8; ball boundaries signal ball_x_l, ball_x_r: unsigned(9 downto 0); signal ball_y_t, ball_y_b: unsigned(9 downto 0); -- reg to track left, top boundary signal ball_x_reg, ball_x_next: unsigned(9 downto 0); signal ball_y_reg, ball_y_next: unsigned(9 downto 0); -- reg to track ball speed signal x_delta_reg, x_delta_next: unsigned(9 downto 0); signal y_delta_reg, y_delta_next: unsigned(9 downto 0); -- ball velocity can be pos or neg constant BALL_V_P: unsigned(9 downto 0) := to_unsigned(2,10); constant BALL_V_N: unsigned(9 downto 0) := unsigned(to_signed(-2,10)); Moving the Ball in VHDL (1)

13ECE 448 – FPGA and ASIC Design with VHDL type rom_type is array (0 to 7) of std_logic_vector(0 to 7); constant BALL_ROM: rom_type := ( " ", -- **** " ", -- ****** " ", -- ******** " ", -- ****** " " -- **** ); signal rom_addr, rom_col: unsigned(2 downto 0); signal rom_data: std_logic_vector(7 downto 0); signal rom_bit: std_logic; Moving the Ball in VHDL (2)

14ECE 448 – FPGA and ASIC Design with VHDL ball_x_l <= ball_x_reg; ball_y_t <= ball_y_reg; ball_x_r <= ball_x_l + BALL_SIZE - 1; ball_y_b <= ball_y_t + BALL_SIZE - 1; -- pixel within ball sq_ball_on <= '1' when (ball_x_l<=pix_x) and (pix_x<=ball_x_r) and (ball_y_t<=pix_y) and (pix_y<=ball_y_b) else '0'; Moving the Ball in VHDL (3)

15ECE 448 – FPGA and ASIC Design with VHDL -- map current pixel location to ROM addr/col rom_addr <= pix_y(2 downto 0) - ball_y_t(2 downto 0); rom_col <= pix_x(2 downto 0) - ball_x_l(2 downto 0); rom_data <= BALL_ROM(to_integer(rom_addr)); rom_bit <= rom_data(to_integer(rom_col)); -- pixel within ball rd_ball_on <= '1' when (sq_ball_on='1') and (rom_bit='1') else '0'; -- ball rgb output ball_rgb <= "100"; -- red Moving the Ball in VHDL (4)

16ECE 448 – FPGA and ASIC Design with VHDL -- new ball position ball_x_next <= ball_x_reg + x_delta_reg when refr_tick='1' else ball_x_reg ; ball_y_next <= ball_y_reg + y_delta_reg when refr_tick='1' else ball_y_reg ; Moving the Ball in VHDL (5)

17ECE 448 – FPGA and ASIC Design with VHDL process(x_delta_reg, y_delta_reg, ball_x_l, ball_x_r, ball_y_t, ball_y_b, bar_y_t, bar_y_b) begin x_delta_next <= x_delta_reg; y_delta_next <= y_delta_reg; if ball_y_t < 1 then -- reach top y_delta_next <= BALL_V_P; elsif ball_y_b > (MAX_Y-1) then -- reach bottom y_delta_next <= BALL_V_N; elsif ball_x_l <= WALL_X_R then -- reach wall x_delta_next <= BALL_V_P; -- bounce back elsif (BAR_X_L<=ball_x_r) and (ball_x_r<=BAR_X_R) then -- reach x of right bar if (bar_y_t<=ball_y_b) and (ball_y_t<=bar_y_b) then x_delta_next <= BALL_V_N; --hit, bounce back end if; end process; Moving the Ball in VHDL (6)

18ECE 448 – FPGA and ASIC Design with VHDL process (clk, reset) begin if reset='1' then ball_x_reg '0'); ball_y_reg '0'); x_delta_reg <= BALL_V_P; y_delta_reg <= BALL_V_P; elsif (clk'event and clk='1') then ball_x_reg <= ball_x_next; ball_y_reg <= ball_y_next; x_delta_reg <= x_delta_next; y_delta_reg <= y_delta_next; end if; end process; Moving the Ball in VHDL (7)

19ECE 448 – FPGA and ASIC Design with VHDL pix_x <= unsigned(pixel_x); pix_y <= unsigned(pixel_y); -- refr_tick: 1-clock tick asserted at start of v-sync -- i.e., when the screen is refreshed (60 Hz) refr_tick <= '1' when (pix_y=481) and (pix_x=0) else '0'; Generating ref_tick in VHDL

20 Vertical Synchronization ECE 448 – FPGA and ASIC Design with VHDL