Skip to content

Refactored SPI peripheral

Eclipse Webmaster requested to merge github/fork/JacobPease/main into main

Created by: JacobPease

  • Refactored SPI peripheral based on SPI controller module. Works in tests/custom/spitest.
  • Fixed enabling of TransmitFIFOReadIncrement and ReceiveFIFOWriteIncrement
  • Fixed issues relating to SCLKenable and TransmitStart. Works at multiple dividers now, instead of just SckDiv = 0.
  • Added changed SPI controller module. New signal TransmitStartD that starts the FSM based on SCLKenable. TransmitStart is responsible for resetting SCLKenable and loading the Transmit Shift Register.
  • Fixed FSM to continue transmitting after delay.
  • Refactored SPI passes regression save for hardware interlock tests.
  • Fixing latches.
  • Fixed lint issues.
  • Fixed ShiftEdge and SampleEdge to not always include PhaseOneOffset. Before, it worked in simulation, but not on the FPGA.
  • Changed the condition for TransmitStart fsm to avoid edge condition.
  • Cleaned up some code. Still more work to do there.
  • Wrote a script that can take hexadecimal bytes from a file and write them to an output file and an sd card.
  • Added usage and help functions to write-bytes.sh
  • Reverted bootloader optimizations to second iteration. Working on last optimization.

Merge request reports

Loading