I had mentioned in the last log that I created the footprint wrong for the HyperRAM device. Well my first bosonFrameGrabber PCB had the same errata.
data:image/s3,"s3://crabby-images/6a6d4/6a6d4282482a10b7e43152c6d44f03e8999a03b5" alt=""
I was able to use this board as a test of my BGA soldering. I'd only ever soldered 0.8mm pitch BGA packages, and the HX8K was in a 0.5mm pitch package! Additionally in order to reduce board size I required a pogo-pin based JTAG connection. Luckily they did not have any errata, and worked great! (My FPGA JTAG programmer is a custom breakout for: https://github.com/esden/ftdi-multitool)
data:image/s3,"s3://crabby-images/02591/0259116bc7d5d73b71827828bf8ca826b584b075" alt=""
v1_01
This version had an updated HyperRAM footprint, and was also my first time ordering form JLC PCB. Surprisingly their standard service handles the 3.5/3.5mil trace/space and the 0.2mm drill required for the 0.5mm BGA pitch.
data:image/s3,"s3://crabby-images/ac6d4/ac6d42d826906a9f0197261878e5e280c6189b01" alt=""
This version actually worked! I was able to port the example project of picosoc over very easily! (https://github.com/cliffordwolf/picorv32/tree/master/picosoc)
data:image/s3,"s3://crabby-images/09f36/09f365af74efb51e965c5a3171e1dfaad84e9115" alt=""
data:image/s3,"s3://crabby-images/62f08/62f08d914cebbd96c1107e8c90e79900db569e8c" alt=""
Working ontop of a working example is great. Really gives you a nice sandbox to adjust bits and pieces. If anything breaks you can backtrack to your last commit to determine the breaking changes.
data:image/s3,"s3://crabby-images/cd4ba/cd4ba3524c4c0d1ab7010c3c012b7665b98f7441" alt=""
I especially like the basic example code included with picosoc. It's all contained in a single file, and creates a simple prompt that enable you to interact with your hardware though a serial terminal. Adding function stubs to the prompt is super easy. Especially for a firmware engineer like me, it feel safe and familiar.
Over the course of a week I designed up a simple verilog block to capture a parallel stream, GPIO register, hyperram wrapper (based off BML's excelent work https://github.com/blackmesalabs/hyperram)
With these pieces I was able to jump back into firmware, add a FatFs driver using bit-banged IO, and capture this image!
data:image/s3,"s3://crabby-images/19558/195580267e723386d905d5a5809854ac0486d1e6" alt=""
A few issues with this image. I have the endianess wrong in this capture, and I had missed a single DWORD (2 pixels) at the start. But considering how far I had come in a week, this was a success!
Also due to the Bit-Banged SPI SD card interface, this 320x256 pixel image, at 320kb in size (16bbp) took around 15s to save.
Now to optimize!
Discussions
Become a Hackaday.io Member
Create an account to leave a comment. Already have an account? Log In.