Pages

Friday, March 08, 2013

Testing CPLD notes


Now I am reading the section on test.xsvf.



Guzunty Pi Construction guide - campbellsan 2013feb

https://github.com/Guzunty/Pi/wiki/Construction-guide

...


5.1 Load program

sudo gz_load gz_test.xsvf

5.2 Run test simply turns on the hardware clock on GPIO4.

sudo ./gz_test


Check the outputs on the header pins. The pins will alternate between 0v and 3.3v.

[If you are using a multimeter to do this, please look at the third to last bullet point below.]

The pins oscillate in four groups of 8 (but see next bullet below), with the lowest bit having a frequency of about 9Hz and each successive bit oscillating half as quickly as its neighbour.

The groups are:

FB1_2 through FB2_5, 

FB2_6 through FB3_9 and 

FB3_11 through FB4_8. 

Group 4 comprises FB4_11 through FB4_17 plus GTS1, GTS2, GSR, GCK2. 

Finally, GCK3 is not part of a group. It oscillates at the slowest rate, cycling about every 12 seconds.


To maximise protection to your Pi, there is no output expected on some P2 pins (FB4_8 through FB4_17), nor on GTS1, GTS2, GSR or GCK1. These pins are oscillating at the CPLD itself, but they are not brought out to the header because they have Raspberry Pi GPIO pins connected to them. You can change this to bring more pins out to P2 by bridging some of the solder pads on the underside of the PCB. However, we recommend you wait until you have gained some experience using the Guzunty in its standard configuration before doing this.

If this is what you find, well done. The outputs are oscillating and your Guzunty is working as it should.

Continue to check that all header pins are oscillating using the multimeter. If you have an oscilloscope you can look at the waveforms to ensure that they are nice and clean.

If you are using an oscilloscope and wish to speed up the rate at which the pins change, you can change the call to gz_clock_ena() so that it passes a smaller divisor (the second parameter).

Conversely, a multimeter can't show a signal changing at 9Hz. It will instead show an averaged value, something around 1.6v. To see the signals changing, you may wish to slow the clock by passing a larger divisor to gz_clock_ena(). Be aware if you do this, that the top bit may take a minute or two to toggle. Oh and don't forget to run make again or your change won't make it into the executable.

Press any key to exit the test program.

You are now ready to try out some of the other cores on this site.

.END

...

No comments:

Post a Comment