You might have heard Hello World! in almost all programming languages when the language is introduced. Today is the time to say Bye World! as it is the last official day of Google Summer of Code 2014. This is by no means to say that this blog is dead. This blog will continue to survive and i will continue to contribute after today. It was a good learning exercise and learning should not stop.
Thanks to TimVideos, Google and all those who shaped, mentored and gave feedback about the project.
Looking back, the proposal went through several iterations of proposal before being accepted. Right from the beginning, the expectations were high and that was a good motivation to work. The start of the project was very broad : looking this, evaluating that etc etc. After a while, things started to converge. As the time went by, i started to become more independent: i only had one VC with my mentor after midterm. Being independent is a good thing and i want to thank my mentor that he enforced this. Overall more time was spent debugging as big portion of the project was integration and testing on the host PC.
If you have comments or questions, please keep posting. Besides me, you are going to make this blog alive !
Monday, August 18, 2014
Thursday, August 14, 2014
Final Report and Documentation
Today was spent making final report and finishing Documentation. Bits and pieces of Documentation are still left which i will get to later. They don't need to be addressed right away.
Please review these and share your comments. I might not be able to address your comments immediately as i am feeling unwell.
Please review these and share your comments. I might not be able to address your comments immediately as i am feeling unwell.
Wednesday, August 13, 2014
Documentation Continues towards finishing
Today was spent updating the bitbucket repository and Documentation. The Documentation refers to bitbucket quite a bit. Besides that i uploaded the static image Demo (see yesterday's post as well).
Now I hope to get sometime to work on DDR2 as that is in good progress. I hope to finish this bonus step by Friday.
Now I hope to get sometime to work on DDR2 as that is in good progress. I hope to finish this bonus step by Friday.
Tuesday, August 12, 2014
Documentation and adding test images continues
Today, i added a test image generated from VTC_DEMO (see yesterday's post). What this means is that besides RGB loop, now this test image can be seen. You need to select this test image by turning switch sw7 up on the Atlys FPGA. Previously, the ideas was to use switches sw7 and sw6 for future purposes. But today i ended up using sw7 for test image. Here is a Demo of the test image.
This also brings us closer to DDR2 integration. Right now, we are confident that HDMI traffic from VTC_DEMO is correctly captured in a file which is then read by packetizer using $readmemb. $readmemb is synthesized into BRAM or LUTs. That is how test image is read by packetizer, which eventually sends it to downstream MAC and off to the destination PC.
Documentation has been updated as well. It will continue this week.
Please share your comments directly on the Documentation or here.
Thanks
This also brings us closer to DDR2 integration. Right now, we are confident that HDMI traffic from VTC_DEMO is correctly captured in a file which is then read by packetizer using $readmemb. $readmemb is synthesized into BRAM or LUTs. That is how test image is read by packetizer, which eventually sends it to downstream MAC and off to the destination PC.
Documentation has been updated as well. It will continue this week.
Please share your comments directly on the Documentation or here.
Thanks
Monday, August 11, 2014
Spending sometime working on DDR2 interface and resuming Documentation
If you recall, i had started Specification document for the project. Now is the time to put more writing into it and complete it by the end of this week by Sunday. I also spent sometime working on DDR2 interface today. From now on, more time (or perhaps most of the time) will be spent on the documentation and less on DDR2 integration. If documentation is complete and there is time left, DDR2 integration will continue. For DDR2 integration, we are going to use VTC_DEMO from Xilinx Application Note 495 as HDMI source. So HDMI traffic (720p) from VTC_DEMO will be written to DDR2 which will then be read by RTP packetizer and sent as RTP packets across 1 Gbps link to the host PC. Host PC will decode these packets using Gstreamer and play them back. I hope that was a good summary.
Please look at the Specification document for some new sections on HDMI. The ideas is to put the following sections so anyone (beginner with no knowledge or an expert) can understand the project and be able to reuse it. Following sections are going to be added to the rest of the documentation. This is not a complete list and things may be added or subtracted as needed.
1) HDMI basic explanation (what is a 720p frame, what are the relevant signals and how to know when a line (row) starts and when it is finished and when a frame starts and when it is finished?
2) Gigabit Ethernet MAC
3) RTP Packetizer
4) Frame Calculation
5) Testing on the Host PC using Gstreamer (how to configure the host PC, how to increase or decrease the frame rate using switches on Atlys FPGA)
6) Future Directions
Documentation is to be continued ...
Please look at the Specification document for some new sections on HDMI. The ideas is to put the following sections so anyone (beginner with no knowledge or an expert) can understand the project and be able to reuse it. Following sections are going to be added to the rest of the documentation. This is not a complete list and things may be added or subtracted as needed.
1) HDMI basic explanation (what is a 720p frame, what are the relevant signals and how to know when a line (row) starts and when it is finished and when a frame starts and when it is finished?
2) Gigabit Ethernet MAC
3) RTP Packetizer
4) Frame Calculation
5) Testing on the Host PC using Gstreamer (how to configure the host PC, how to increase or decrease the frame rate using switches on Atlys FPGA)
6) Future Directions
Documentation is to be continued ...
Sunday, August 10, 2014
Successful transmission of packets and recovery
Hi,
Good to see you after a break. I was at a Conference last week and after the end of each day, i dedicated some time to figuring out why packets were getting dropped and how to correct that. Finally, i got it working after lot of debugging using simulation, Chipscope pro and Googling. Anyway, i tried a couple of options. Some worked and some didn't. These were:
1) Adding latency (number of milliseconds before a packet is declared dropped) to the Gstreamer command
time gst-launch-1.0 -v udpsrc uri=udp://192.168.1.1:5004 caps="application/x-rtp, media=(string)video, clock-rate=(int)90000, encoding-name=(string)RAW, sampling=(string)RGB, depth=(string)8, width=(string)1280, height=(string)720" ! rtpbin latency=1 ! rtpvrawdepay ! videoconvert ! autovideosink
I also tried with latency of 0 and it worked. Now the inter-packet delay is configurable using Atlys Switches sw0 to sw5. The default delay is 3000 clock cycles which corresponds to approximately 30 fps. Here is the configuration.
sw5 sw4 sw3 sw2 sw1 sw0 Delay in clock cycles
0 0 0 0 0 0 3000
0 0 0 0 0 1 2625
0 0 0 0 1 0 2250
0 0 0 0 1 1 1875
0 0 0 1 0 0 1500
0 0 0 1 0 1 1125
0 0 0 1 1 0 750
0 0 0 1 1 1 375
2) By Tcp tuning in Linux and Windows 7
I tried without tuning and it worked. The tuning was done to see how much of inter-packet delay can be decreased. It turned out that as you approach to 0 inter-packet delay, Tcp tuning does not work
3) Going from Cat 5 to Cat 6 cable and it didn't make a difference.
4) Going from Linux to Windows 7 as my laptop had Windows 7 and i was stuck with this last week. It was not different going from Linux to Windows 7 except that Gstreamer didn't work in Window 7 for some reason.
Here is a quick demo. You will see frame rate going up (faster RGB pattern) and then going down (slow RGB pattern)
Now i shall work on DDR2 integration and documentation this week.
Please give your valuable feedback
Good to see you after a break. I was at a Conference last week and after the end of each day, i dedicated some time to figuring out why packets were getting dropped and how to correct that. Finally, i got it working after lot of debugging using simulation, Chipscope pro and Googling. Anyway, i tried a couple of options. Some worked and some didn't. These were:
1) Adding latency (number of milliseconds before a packet is declared dropped) to the Gstreamer command
time gst-launch-1.0 -v udpsrc uri=udp://192.168.1.1:5004 caps="application/x-rtp, media=(string)video, clock-rate=(int)90000, encoding-name=(string)RAW, sampling=(string)RGB, depth=(string)8, width=(string)1280, height=(string)720" ! rtpbin latency=1 ! rtpvrawdepay ! videoconvert ! autovideosink
I also tried with latency of 0 and it worked. Now the inter-packet delay is configurable using Atlys Switches sw0 to sw5. The default delay is 3000 clock cycles which corresponds to approximately 30 fps. Here is the configuration.
sw5 sw4 sw3 sw2 sw1 sw0 Delay in clock cycles
0 0 0 0 0 0 3000
0 0 0 0 0 1 2625
0 0 0 0 1 0 2250
0 0 0 0 1 1 1875
0 0 0 1 0 0 1500
0 0 0 1 0 1 1125
0 0 0 1 1 0 750
0 0 0 1 1 1 375
0 0 1 0 0 0 5500
0 1 0 0 0 0 8000
0 1 1 0 0 0 10500
1 0 0 0 0 0 13000
1 0 1 0 0 0 15500
1 1 0 0 0 0 18000
1 1 1 0 0 0 20500
0 1 0 0 0 0 8000
0 1 1 0 0 0 10500
1 0 0 0 0 0 13000
1 0 1 0 0 0 15500
1 1 0 0 0 0 18000
1 1 1 0 0 0 20500
sw6 is reserved for jumbo frame size and sw7 is reserved for 1080p (for future tweaks)
2) By Tcp tuning in Linux and Windows 7
I tried without tuning and it worked. The tuning was done to see how much of inter-packet delay can be decreased. It turned out that as you approach to 0 inter-packet delay, Tcp tuning does not work
3) Going from Cat 5 to Cat 6 cable and it didn't make a difference.
4) Going from Linux to Windows 7 as my laptop had Windows 7 and i was stuck with this last week. It was not different going from Linux to Windows 7 except that Gstreamer didn't work in Window 7 for some reason.
Here is a quick demo. You will see frame rate going up (faster RGB pattern) and then going down (slow RGB pattern)
Now i shall work on DDR2 integration and documentation this week.
Please give your valuable feedback
Subscribe to:
Posts (Atom)