Homework #10
Guidelines
- Complete the answers using the Canvas Quiz
- Digital copies of all code, testbenches, waveforms, etc will be submitted via Canvas and BitBucket.
Assignment
- Complete the development of the example in Lecture 19.
- Modify the lec11 counter component to include a roll signal that
is asserted whenever the counter is at the maximum count value.
In order to accomplish this with the generic counter width
you may need to create a temporary signal that is equal to the
highest count value (see below). Add the roll signal as an output to be displayed just
like the count value on the help menu (FYI, If you load a Capital E and then
count up you can get to max count). Prepare a video demo of your circuit by the beginning of Lecture 20.
Upload a link to the video demo to Canvas. Make sure your video shows the terminal and the
board in operation. Show it counting up, loading a value, and stop it at max count to show the roll signal being high.
- Upload your Lecture_19 project folder to BitBucket.
maxCount <= (others => '1');
Developed Lecture 19 Block Diagram
data:image/s3,"s3://crabby-images/20fac/20facd51fe3edbd32da9044fce0a85f3f7d33b92" alt=""
Note
You will most likely get an error that looks like the following:
'Invoking: MicroBlaze Print Size'
mb-size lab3.elf |tee "lab3.elf.size"
text data bss dec hex filename
8100 272 8244 16616 40e8 lab3.elf
'Finished building: lab3.elf.size'
Building target: lec19.elf
Invoking: MicroBlaze gcc linker
mb-gcc -Wl,-T -Wl, bla bla bla -Wl,--start-group,-lxil,-lgcc,-lc,--end-group
c:/xilinx/14.7/ise_ds/edk/gnu/ bla bla /ld.exe: lec19.elf section `.stack' will not fit in region `microblaze_0_i_bram_ctrl_microblaze_0_d_bram_ctrl'
c:/xilinx/14.7/ise_ds/edk/gnu/ bla bla /ld.exe: region `microblaze_0_i_bram_ctrl_microblaze_0_d_bram_ctrl' overflowed by 80 bytes
collect2: ld returned 1 exit status
make: *** [lec19.elf] Error 1
Look at the MicroBlaze Print Size address editor and you will find that the value
under dec (size of your program (instructions + data) in decimal bytes)
is the 32k you allocated in Vivado for the microblaze memory. You should be good but
potentially you may have to increase the size of the instruction and data memory in Vivado and
recompile (see figure below). As you will see in the Print Size output
above, I ran into this problem when my program JUST exceeded the 16K
I had allocated for it in Vivado.
data:image/s3,"s3://crabby-images/d7617/d76178cb58b9d68e59eb056ea00a0ac14a5b4379" alt=""
After you make this change, you will need to increase the stack and heap
space inside SDK. Since you already started with 32K you may only have to
increase the stack and heap in SDK. To do this, open the linker script (lscript.ld) and then
increase the size of your memory to reflect the size entered in Vivado. Finally
you can increase the stack and heap sizes to cover that needed in the error
message.