mirror of
				https://github.com/RobotechLille/cdf2018-principal
				synced 2025-10-25 02:03:31 +02:00 
			
		
		
		
	FPGA : Pipelinage du module de communication
This commit is contained in:
		
							parent
							
								
									68c7223fe4
								
							
						
					
					
						commit
						6013d6c9a9
					
				
					 5 changed files with 133 additions and 134 deletions
				
			
		|  | @ -174,11 +174,14 @@ build/%.o: %.vhd | ||||||
| build/%_tb: build/%_tb.o $(addprefix build/,$(subst .vhd,.o,$(VHDSOURCE))) | build/%_tb: build/%_tb.o $(addprefix build/,$(subst .vhd,.o,$(VHDSOURCE))) | ||||||
| 	ghdl -e $(GHDL_FLAGS) --workdir="$(shell dirname "$@")" -o "$(shell echo "$@" | tr A-Z a-z)" "$(basename $(notdir $<))" | 	ghdl -e $(GHDL_FLAGS) --workdir="$(shell dirname "$@")" -o "$(shell echo "$@" | tr A-Z a-z)" "$(basename $(notdir $<))" | ||||||
| 
 | 
 | ||||||
|  | %_test: build/%_tb | ||||||
|  | 	(cd "$(shell dirname "$<")"; time ghdl -r "$(basename $(notdir $<))") | ||||||
|  | 
 | ||||||
| build/%_tb.vcd: build/%_tb | build/%_tb.vcd: build/%_tb | ||||||
| 	(cd "$(shell dirname "$<")"; time ghdl -r "$(basename $(notdir $<))" --vcd="../$@" ) | 	(cd "$(shell dirname "$<")"; time ghdl -r "$(basename $(notdir $<))" --vcd="../$@") | ||||||
| 
 | 
 | ||||||
| build/%_tb.ghw: build/%_tb | build/%_tb.ghw: build/%_tb | ||||||
| 	(cd "$(shell dirname "$<")"; time ghdl -r "$(basename $(notdir $<))" --wave="../$@" ) | 	(cd "$(shell dirname "$<")"; time ghdl -r "$(basename $(notdir $<))" --wave="../$@") | ||||||
| 
 | 
 | ||||||
| %_wave: build/%_tb.ghw | %_wave: build/%_tb.ghw | ||||||
| 	gtkwave --save "$(notdir $(basename $<)).gtkw" "$<" | 	gtkwave --save "$(notdir $(basename $<)).gtkw" "$<" | ||||||
|  |  | ||||||
|  | @ -9,11 +9,11 @@ entity communication is | ||||||
|              reset : in std_logic; |              reset : in std_logic; | ||||||
|              left : in integer; |              left : in integer; | ||||||
|              right : in integer; |              right : in integer; | ||||||
|              zerocoder : out std_logic; |              zerocoder : out std_logic := '0'; | ||||||
|              front : in integer; |              front : in integer; | ||||||
|              back : in integer; |              back : in integer; | ||||||
|              txData : out std_logic_vector(7 downto 0); |              txData : out std_logic_vector(7 downto 0) := x"00"; | ||||||
|              txStb : out std_logic; |              txStb : out std_logic := '0'; | ||||||
|              txAck : in std_logic; |              txAck : in std_logic; | ||||||
|              rxData : in std_logic_vector(7 downto 0); |              rxData : in std_logic_vector(7 downto 0); | ||||||
|              rxStb : in std_logic |              rxStb : in std_logic | ||||||
|  | @ -30,95 +30,73 @@ architecture Behavioral of communication is | ||||||
|     constant F2AI_CAPT : std_logic_vector(7 downto 0) := x"43"; -- 'C' |     constant F2AI_CAPT : std_logic_vector(7 downto 0) := x"43"; -- 'C' | ||||||
|     constant F2AT_CAPT : std_logic_vector(7 downto 0) := x"63"; -- 'c' |     constant F2AT_CAPT : std_logic_vector(7 downto 0) := x"63"; -- 'c' | ||||||
| 
 | 
 | ||||||
|     type readMessages is (none, F2AT_CAPTs); |  | ||||||
|     type sendMessages is (none, A2FD_PINGs, F2AI_CODERs, F2AI_CAPTs, F2AD_ERR_UNKNOWN_CODEs); |  | ||||||
| 
 |  | ||||||
|     constant SENDQUEUE_SIZE : integer := 16; |  | ||||||
|     type sendQueueMemorya is array (0 to SENDQUEUE_SIZE - 1) of sendMessages; |  | ||||||
| 
 |  | ||||||
|     signal frontTrigger : integer := 0; |     signal frontTrigger : integer := 0; | ||||||
|     signal backTrigger : integer := 0; |     signal backTrigger : integer := 0; | ||||||
|     signal triggerSet : std_logic := '0'; |     signal triggerSet : std_logic := '0'; | ||||||
| 
 | 
 | ||||||
|     signal txStbs : std_logic := '0'; |     type readMessages is (F2AT_CAPTs); | ||||||
|  |     signal readMessage : readMessages; | ||||||
|  |     signal readSize : integer := 0; | ||||||
|  |     signal readOffset : integer := 0; | ||||||
|  |     signal readData : std_logic_vector(63 downto 0) := (others => '0'); -- Max message size (will be trimmed down by the synthetizer) | ||||||
|  | 
 | ||||||
|  |     type sendMessages is (A2FD_PINGs, F2AI_CODERs, F2AI_CAPTs, F2AD_ERR_UNKNOWN_CODEs); | ||||||
|  |     constant SENDQUEUE_SIZE : integer := 16; | ||||||
|  |     type sendQueueMemorya is array (0 to SENDQUEUE_SIZE - 1) of sendMessages; | ||||||
|  |     signal sendQueueMemory : sendQueueMemorya; | ||||||
|  |     signal sendTail : integer := 0; | ||||||
|  |     signal sendHead : integer := 0; | ||||||
|  |     signal sendLooped : std_logic := '0'; | ||||||
|  | 
 | ||||||
|  |     signal sendAvailable: std_logic := '0'; | ||||||
|  |     signal sendBegun : std_logic := '0'; | ||||||
|  |     signal sendOffset : integer := 0; | ||||||
|  |     signal sendSize : integer := 0; | ||||||
|  |     signal sendData : std_logic_vector(63 downto 0) := (others => '0'); -- Max message size (will be trimmed down by the synthetizer) | ||||||
| 
 | 
 | ||||||
| begin | begin | ||||||
| 
 | 
 | ||||||
|     txStb <= txStbs; |  | ||||||
| 
 |  | ||||||
|     readsendFA : process(clock, reset) |     readsendFA : process(clock, reset) | ||||||
| 
 | 
 | ||||||
|         variable readMessage : readMessages := none; |  | ||||||
|         variable readSize : integer := 0; |  | ||||||
|         variable readOffset : integer := 0; |  | ||||||
|         variable readData : std_logic_vector(63 downto 0); -- Max message size (will be trimmed down by the synthetizer) |  | ||||||
| 
 |  | ||||||
|         variable sendMessage : sendMessages := none; |  | ||||||
|         variable sendOffset : integer := 0; |  | ||||||
|         variable sendSize : integer := 0; |  | ||||||
|         variable sendData : std_logic_vector(63 downto 0); -- Max message size (will be trimmed down by the synthetizer) |  | ||||||
| 
 |  | ||||||
|         -- Send queue |  | ||||||
|         variable sendQueueMemory : sendQueueMemorya; |  | ||||||
|         variable sendTail : integer := 0; |  | ||||||
|         variable sendHead : integer := 0; |  | ||||||
|         variable sendLooped : boolean := false; |  | ||||||
| 
 |  | ||||||
|         procedure pushSend |         procedure pushSend | ||||||
|         (message : in sendMessages) is |         (message : in sendMessages) is | ||||||
|         begin |         begin | ||||||
|             sendQueueMemory(sendHead) := message; |             sendQueueMemory(sendHead) <= message; | ||||||
|             if sendHead < SENDQUEUE_SIZE - 1 then |             if sendHead < SENDQUEUE_SIZE - 1 then | ||||||
|                 sendHead := sendHead + 1; |                 sendHead <= sendHead + 1; | ||||||
|             else |             else | ||||||
|                 sendHead := 0; |                 sendHead <= 0; | ||||||
|                 sendLooped := true; |                 sendLooped <= '1'; | ||||||
|             end if; |             end if; | ||||||
|         end pushSend; |         end pushSend; | ||||||
| 
 | 
 | ||||||
|         procedure popSend |  | ||||||
|         (message : out sendMessages) is |  | ||||||
|         begin |  | ||||||
|             if sendTail < sendHead or sendLooped then |  | ||||||
|                 message := sendQueueMemory(sendTail); |  | ||||||
|                 if sendTail < SENDQUEUE_SIZE - 1 then |  | ||||||
|                     sendTail := sendTail + 1; |  | ||||||
|                 else |  | ||||||
|                     sendTail := 0; |  | ||||||
|                     sendLooped := false; |  | ||||||
|                 end if; |  | ||||||
|             else |  | ||||||
|                 message := none; |  | ||||||
|             end if; |  | ||||||
|         end popSend; |  | ||||||
| 
 |  | ||||||
|     begin |     begin | ||||||
|         if reset = '1' then |         if reset = '1' then | ||||||
|             readMessage := none; |  | ||||||
|             readOffset := 0; |  | ||||||
|             readSize := 0; |  | ||||||
| 
 |  | ||||||
|             sendMessage := none; |  | ||||||
|             sendOffset := 0; |  | ||||||
|             sendSize := 0; |  | ||||||
| 
 |  | ||||||
|             sendTail := 0; |  | ||||||
|             sendHead := 0; |  | ||||||
|             sendLooped := false; |  | ||||||
| 
 |  | ||||||
|             frontTrigger <= 0; |             frontTrigger <= 0; | ||||||
|             backTrigger <= 0; |             backTrigger <= 0; | ||||||
|  |             triggerSet <= '0'; | ||||||
|  |             readSize <= 0; | ||||||
|  |             readOffset <= 0; | ||||||
|  |             readData <= (others => '0'); | ||||||
|  |             sendTail <= 0; | ||||||
|  |             sendHead <= 0; | ||||||
|  |             sendLooped <= '0'; | ||||||
|  |             sendAvailable<= '0'; | ||||||
|  |             sendBegun <= '0'; | ||||||
|  |             sendOffset <= 0; | ||||||
|  |             sendSize <= 0; | ||||||
|  |             sendData <= (others => '0'); | ||||||
|  |             txStb <= '0'; | ||||||
|             zerocoder <= '0'; |             zerocoder <= '0'; | ||||||
|             txData <= x"00"; |             txData <= x"00"; | ||||||
|             triggerSet <= '0'; |  | ||||||
|         else |         else | ||||||
|             if rising_edge(clock) then |             if rising_edge(clock) then | ||||||
|                 zerocoder <= '0'; |                 zerocoder <= '0'; | ||||||
| 
 | 
 | ||||||
|                 -- If read something |                 -- If read something | ||||||
|                 if rxStb = '1' then |                 if rxStb = '1' then -- Incomming character | ||||||
|                     if readSize = 0 then |                     if readSize = 0 then -- Beginning of message | ||||||
|                         readSize := 0; |                         readSize <= 0; | ||||||
|                         case rxData is |                         case rxData is | ||||||
|                             when A2FD_PING => |                             when A2FD_PING => | ||||||
|                                 pushSend(A2FD_PINGs); |                                 pushSend(A2FD_PINGs); | ||||||
|  | @ -127,14 +105,18 @@ begin | ||||||
|                             when F2AI_CAPT => |                             when F2AI_CAPT => | ||||||
|                                 pushSend(F2AI_CAPTs); |                                 pushSend(F2AI_CAPTs); | ||||||
|                             when F2AT_CAPT => |                             when F2AT_CAPT => | ||||||
|                                 readMessage := F2AT_CAPTs; |                                 readMessage <= F2AT_CAPTs; | ||||||
|                                 readSize := 4; |                                 readSize <= 4; | ||||||
|                             when others => |                             when others => | ||||||
|                                 pushSend(F2AD_ERR_UNKNOWN_CODEs); |                                 pushSend(F2AD_ERR_UNKNOWN_CODEs); | ||||||
|                         end case; |                         end case; | ||||||
|                     else |                     else -- Rest of message | ||||||
|                         readData((readOffset + 1) * 8 - 1 downto readOffset * 8) := rxData; |                         if readOffset < readSize then | ||||||
|                         if readOffset = readSize - 1 then |                             readData((readOffset + 1) * 8 - 1 downto readOffset * 8) <= rxData; | ||||||
|  |                             readOffset <= readOffset + 1; | ||||||
|  |                         end if; | ||||||
|  |                     end if; | ||||||
|  |                 elsif readSize > 0 and readOffset = readSize then -- Rest of message ended | ||||||
|                     case readMessage is |                     case readMessage is | ||||||
|                         when F2AT_CAPTs => |                         when F2AT_CAPTs => | ||||||
|                             frontTrigger <= to_integer(unsigned(readData(15 downto 0))); |                             frontTrigger <= to_integer(unsigned(readData(15 downto 0))); | ||||||
|  | @ -143,64 +125,65 @@ begin | ||||||
|                         when others => |                         when others => | ||||||
|                             pushSend(F2AD_ERR_UNKNOWN_CODEs); |                             pushSend(F2AD_ERR_UNKNOWN_CODEs); | ||||||
|                     end case; |                     end case; | ||||||
|                             readMessage := none; |                     readOffset <= 0; | ||||||
|                             readOffset := 0; |                     readSize <= 0; | ||||||
|                             readSize := 0; |                 elsif (triggerSet = '1' and ((front > frontTrigger) or (back > backTrigger))) then | ||||||
|                         else |  | ||||||
|                             readOffset := readOffset + 1; |  | ||||||
|                         end if; |  | ||||||
| 
 |  | ||||||
|                     end if; |  | ||||||
|                 end if; |  | ||||||
| 
 |  | ||||||
|                 if (triggerSet = '1' and ((front > frontTrigger) or (back > backTrigger))) then |  | ||||||
|                     pushSend(F2AI_CAPTs); |                     pushSend(F2AI_CAPTs); | ||||||
|                     triggerSet <= '0'; |                     triggerSet <= '0'; | ||||||
|                 end if; |                 end if; | ||||||
| 
 | 
 | ||||||
|                 -- If what was sent is acknowledged or nothing is being sent atm |                 if sendAvailable = '0' then -- If no message is being sent | ||||||
|                 if txStbs = '0' or txAck = '1' then |                     if sendTail < sendHead or sendLooped = '1' then -- If there is a message in the queue | ||||||
|                     if sendSize = 0 then -- If no data to be sent | 
 | ||||||
|                         popSend(sendMessage); -- See if there a message in the message queue |                         -- Update tail | ||||||
|                         case sendMessage is |                         if sendTail < SENDQUEUE_SIZE - 1 then | ||||||
|                             when none => -- No message available, do nothing |                             sendTail <= sendTail + 1; | ||||||
|  |                         else | ||||||
|  |                             sendTail <= 0; | ||||||
|  |                             sendLooped <= '0'; | ||||||
|  |                         end if; | ||||||
|  | 
 | ||||||
|  |                         sendAvailable <= '1'; | ||||||
|  | 
 | ||||||
|  |                         case sendQueueMemory(sendTail) is | ||||||
|                             when A2FD_PINGs => |                             when A2FD_PINGs => | ||||||
|                                 sendData(7 downto 0) := A2FD_PING; |                                 sendData(7 downto 0) <= A2FD_PING; | ||||||
|                                 sendSize := 1; |                                 sendSize <= 1; | ||||||
|                             when F2AI_CAPTs => |                             when F2AI_CAPTs => | ||||||
|                                 sendData(7 downto 0) := F2AI_CAPT; |                                 sendData(7 downto 0) <= F2AI_CAPT; | ||||||
|                                 sendData(23 downto 8) := std_logic_vector(to_signed(front, 16)); |                                 sendData(23 downto 8) <= std_logic_vector(to_signed(front, 16)); | ||||||
|                                 sendData(39 downto 24) := std_logic_vector(to_unsigned(back, 16)); |                                 sendData(39 downto 24) <= std_logic_vector(to_unsigned(back, 16)); | ||||||
|                                 sendSize := 5; |                                 sendSize <= 5; | ||||||
|                             when F2AI_CODERs => |                             when F2AI_CODERs => | ||||||
|                                 zerocoder <= '1'; |                                 zerocoder <= '1'; | ||||||
|                                 sendData(7 downto 0) := F2AI_CODER; |                                 sendData(7 downto 0) <= F2AI_CODER; | ||||||
|                                 sendData(23 downto 8) := std_logic_vector(to_signed(left, 16)); |                                 sendData(23 downto 8) <= std_logic_vector(to_signed(left, 16)); | ||||||
|                                 sendData(39 downto 24) := std_logic_vector(to_signed(right, 16)); |                                 sendData(39 downto 24) <= std_logic_vector(to_signed(right, 16)); | ||||||
|                                 sendSize := 5; |                                 sendSize <= 5; | ||||||
|                             when others => -- Including F2AD_ERR_UNKNOWN_CODEs |                             when others => -- Including F2AD_ERR_UNKNOWN_CODEs | ||||||
|                                 sendData(7 downto 0) := F2AD_ERR; |                                 sendData(7 downto 0) <= F2AD_ERR; | ||||||
|                                 sendData(15 downto 8) := ERR_UNKNOWN_CODE; |                                 sendData(15 downto 8) <= ERR_UNKNOWN_CODE; | ||||||
|                                 sendSize := 2; |                                 sendSize <= 2; | ||||||
|                         end case; |                         end case; | ||||||
|                     end if; |                     end if; | ||||||
| 
 | 
 | ||||||
|                     if sendSize > 0 then -- If data to be sent |                 else -- If a message is being sent | ||||||
|  |                     if sendBegun = '0' or txAck = '1' then | ||||||
|  |                         sendBegun <= '1'; | ||||||
|  |                         if sendOffset < sendSize then -- There is still data to send | ||||||
|                             txData <= sendData((sendOffset + 1) * 8 - 1 downto sendOffset * 8); |                             txData <= sendData((sendOffset + 1) * 8 - 1 downto sendOffset * 8); | ||||||
|                         txStbs <= '1'; |                             txStb <= '1'; | ||||||
|  |                             sendOffset <= sendOffset + 1; | ||||||
|  |                         else -- There is no more data to send | ||||||
|  |                             sendOffset <= 0; | ||||||
|  |                             txStb <= '0'; | ||||||
|  |                             sendBegun <= '0'; | ||||||
|  |                             sendAvailable <= '0'; | ||||||
|  |                         end if; | ||||||
|  |                     end if; | ||||||
|  |                 end if; | ||||||
| 
 | 
 | ||||||
|                         if sendOffset = sendSize - 1 then -- If it was the last character sent |  | ||||||
|                             sendSize := 0; -- Make next iteration check for send queue |  | ||||||
|                             sendOffset := 0; |  | ||||||
|                         else -- Still data to be sent after that |  | ||||||
|                             sendOffset := sendOffset + 1; |  | ||||||
|                         end if; |  | ||||||
|                     else -- If really no data to be sent |  | ||||||
|                         txStbs <= '0'; |  | ||||||
|                     end if; |  | ||||||
|                 end if; |  | ||||||
|             end if; |             end if; | ||||||
|         end if; |         end if; | ||||||
|     end process; |     end process; | ||||||
| 
 |  | ||||||
| end Behavioral; | end Behavioral; | ||||||
|  |  | ||||||
|  | @ -1,20 +1,20 @@ | ||||||
| [*] | [*] | ||||||
| [*] GTKWave Analyzer v3.3.86 (w)1999-2017 BSI | [*] GTKWave Analyzer v3.3.86 (w)1999-2017 BSI | ||||||
| [*] Tue Feb 27 20:44:59 2018 | [*] Wed Feb 28 14:53:10 2018 | ||||||
| [*] | [*] | ||||||
| [dumpfile] "/home/geoffrey/Documents/Polytech/Robotech/2017-2018/CdF/cdf2018-principal/fpga/build/communication_tb.ghw" | [dumpfile] "/home/geoffrey/Documents/Polytech/Robotech/2017-2018/CdF/cdf2018-principal/fpga/build/communication_tb.ghw" | ||||||
| [dumpfile_mtime] "Tue Feb 27 20:44:10 2018" | [dumpfile_mtime] "Wed Feb 28 14:51:41 2018" | ||||||
| [dumpfile_size] 6988 | [dumpfile_size] 7845 | ||||||
| [savefile] "/home/geoffrey/Documents/Polytech/Robotech/2017-2018/CdF/cdf2018-principal/fpga/communication_tb.gtkw" | [savefile] "/home/geoffrey/Documents/Polytech/Robotech/2017-2018/CdF/cdf2018-principal/fpga/communication_tb.gtkw" | ||||||
| [timestart] 0 | [timestart] 0 | ||||||
| [size] 1600 862 | [size] 1600 862 | ||||||
| [pos] -1 -1 | [pos] -1 -1 | ||||||
| *-29.975166 2184000000 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 | *-30.009827 1783000000 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 | ||||||
| [treeopen] top. | [treeopen] top. | ||||||
| [treeopen] top.communication_tb. | [treeopen] top.communication_tb. | ||||||
| [treeopen] top.communication_tb.dut. | [treeopen] top.communication_tb.dut. | ||||||
| [sst_width] 213 | [sst_width] 213 | ||||||
| [signals_width] 126 | [signals_width] 198 | ||||||
| [sst_expanded] 1 | [sst_expanded] 1 | ||||||
| [sst_vpaned_height] 200 | [sst_vpaned_height] 200 | ||||||
| @28 | @28 | ||||||
|  | @ -29,6 +29,17 @@ top.communication_tb.reset | ||||||
| @28 | @28 | ||||||
| [color] 5 | [color] 5 | ||||||
| top.communication_tb.dut.rxstb | top.communication_tb.dut.rxstb | ||||||
|  | @420 | ||||||
|  | [color] 3 | ||||||
|  | top.communication_tb.dut.sendhead | ||||||
|  | [color] 3 | ||||||
|  | top.communication_tb.dut.sendtail | ||||||
|  | [color] 3 | ||||||
|  | top.communication_tb.dut.sendsize | ||||||
|  | [color] 3 | ||||||
|  | top.communication_tb.dut.sendavailable | ||||||
|  | [color] 3 | ||||||
|  | top.communication_tb.dut.sendbegun | ||||||
| @22 | @22 | ||||||
| [color] 1 | [color] 1 | ||||||
| #{top.communication_tb.txdata[7:0]} top.communication_tb.txdata[7] top.communication_tb.txdata[6] top.communication_tb.txdata[5] top.communication_tb.txdata[4] top.communication_tb.txdata[3] top.communication_tb.txdata[2] top.communication_tb.txdata[1] top.communication_tb.txdata[0] | #{top.communication_tb.txdata[7:0]} top.communication_tb.txdata[7] top.communication_tb.txdata[6] top.communication_tb.txdata[5] top.communication_tb.txdata[4] top.communication_tb.txdata[3] top.communication_tb.txdata[2] top.communication_tb.txdata[1] top.communication_tb.txdata[0] | ||||||
|  | @ -44,12 +55,15 @@ top.communication_tb.dut.txack | ||||||
| top.communication_tb.dut.zerocoder | top.communication_tb.dut.zerocoder | ||||||
| @420 | @420 | ||||||
| [color] 2 | [color] 2 | ||||||
|  | top.communication_tb.dut.left | ||||||
|  | [color] 2 | ||||||
|  | top.communication_tb.dut.right | ||||||
|  | [color] 2 | ||||||
| top.communication_tb.dut.fronttrigger | top.communication_tb.dut.fronttrigger | ||||||
| [color] 2 | [color] 2 | ||||||
| top.communication_tb.dut.backtrigger | top.communication_tb.dut.backtrigger | ||||||
| [color] 2 | [color] 2 | ||||||
| top.communication_tb.dut.front | top.communication_tb.dut.front | ||||||
| @421 |  | ||||||
| [color] 2 | [color] 2 | ||||||
| top.communication_tb.dut.back | top.communication_tb.dut.back | ||||||
| [pattern_trace] 1 | [pattern_trace] 1 | ||||||
|  |  | ||||||
|  | @ -69,10 +69,10 @@ begin | ||||||
|     stimuli : process |     stimuli : process | ||||||
|         variable tampon : multipleChar; |         variable tampon : multipleChar; | ||||||
|     begin |     begin | ||||||
|         left <= 0; |  | ||||||
|         right <= 0; |  | ||||||
|         front <= 0; |         front <= 0; | ||||||
|         back <= 0; |         back <= 0; | ||||||
|  |         left <= 1152; | ||||||
|  |         right <= 11614; | ||||||
|         txAck <= '0'; |         txAck <= '0'; | ||||||
|         rxData <= (others => '0'); |         rxData <= (others => '0'); | ||||||
|         rxStb <= '0'; |         rxStb <= '0'; | ||||||
|  | @ -185,24 +185,23 @@ begin | ||||||
|         assert txStb = '0' report "Not stopping send" severity error; |         assert txStb = '0' report "Not stopping send" severity error; | ||||||
| 
 | 
 | ||||||
|         -- Test encoder |         -- Test encoder | ||||||
|         left <= 1152; |  | ||||||
|         right <= 11614; |  | ||||||
| 
 | 
 | ||||||
|         report "TEST Receiving 'D'" severity note; |         report "TEST Receiving 'D'" severity note; | ||||||
|         rxData <= x"44"; |         rxData <= x"44"; | ||||||
|         rxStb <= '1'; |         rxStb <= '1'; | ||||||
|         wait for TbPeriod; |         wait for TbPeriod; | ||||||
|  |         rxStb <= '0'; | ||||||
|  |         wait for TbPeriod; | ||||||
|         assert zerocoder = '1' report "Not reseting coder values" severity error; |         assert zerocoder = '1' report "Not reseting coder values" severity error; | ||||||
|         left <= 0; |         left <= 0; | ||||||
|         right <= 0; |         right <= 0; | ||||||
|         rxStb <= '0'; |  | ||||||
|         wait for TbPeriod; |         wait for TbPeriod; | ||||||
|         assert zerocoder = '0' report "Not stopping reseting coder values" severity error; |         assert zerocoder = '0' report "Not stopping reseting coder values" severity error; | ||||||
| 
 | 
 | ||||||
|         tampon(0 to 4) := (x"44", x"80", x"04", x"5E", x"2D"); |         tampon(0 to 4) := (x"44", x"80", x"04", x"5E", x"2D"); | ||||||
|         for I in 0 to 4 loop |         for I in 0 to 4 loop | ||||||
|             wait for 100 ns; |             wait for 100 ns; | ||||||
|             assert txData = tampon(I) report "Not sent correct data, got " & integer'image(to_integer(unsigned(txData))) & ", expected " & integer'image(to_integer(unsigned(tampon(I))))severity error; |             assert txData = tampon(I) report "Not sent correct data, got " & integer'image(to_integer(unsigned(txData))) & ", expected " & integer'image(to_integer(unsigned(tampon(I)))) severity error; | ||||||
|             assert txStb = '1' report "Not sending" severity error; |             assert txStb = '1' report "Not sending" severity error; | ||||||
| 
 | 
 | ||||||
|             wait for 100 ns; |             wait for 100 ns; | ||||||
|  |  | ||||||
|  | @ -1,10 +1,10 @@ | ||||||
| [*] | [*] | ||||||
| [*] GTKWave Analyzer v3.3.86 (w)1999-2017 BSI | [*] GTKWave Analyzer v3.3.86 (w)1999-2017 BSI | ||||||
| [*] Wed Feb 28 09:53:14 2018 | [*] Wed Feb 28 11:47:06 2018 | ||||||
| [*] | [*] | ||||||
| [dumpfile] "/home/geoffrey/Documents/Polytech/Robotech/2017-2018/CdF/cdf2018-principal/fpga/build/fir_tb.ghw" | [dumpfile] "/home/geoffrey/Documents/Polytech/Robotech/2017-2018/CdF/cdf2018-principal/fpga/build/fir_tb.ghw" | ||||||
| [dumpfile_mtime] "Wed Feb 28 09:53:10 2018" | [dumpfile_mtime] "Wed Feb 28 11:46:54 2018" | ||||||
| [dumpfile_size] 595494 | [dumpfile_size] 458919 | ||||||
| [savefile] "/home/geoffrey/Documents/Polytech/Robotech/2017-2018/CdF/cdf2018-principal/fpga/fir_tb.gtkw" | [savefile] "/home/geoffrey/Documents/Polytech/Robotech/2017-2018/CdF/cdf2018-principal/fpga/fir_tb.gtkw" | ||||||
| [timestart] 0 | [timestart] 0 | ||||||
| [size] 1600 862 | [size] 1600 862 | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue