Skip to content

Latest commit

 

History

History
32 lines (14 loc) · 2.27 KB

README.md

File metadata and controls

32 lines (14 loc) · 2.27 KB

Bilkent University Engineering Department: CS 223 - Digital Design Term Project

FPGA Implementation of Vigenère Cipher by using Basys 3 Artix-7 FPGA and SystemVerilog HDL

Main Blocks: Keyboard Analyzer, VGA Display, text operator.

Vigenère Cipher: It is a simple form of polyalphabetic substitution, simplified special case of the Enigma machine.

How does it work?

  • Keyboard Analyzer takes the input from keyboard, receives a 11-bit data which contains start and stop bits, rest 8-bit is the scan code of the pressed key at the keyboard. Analyzer tries to extract that scan code from 11-bit data which can be quite hard sometimes. because scan codes are somewhat are in reverse order, meaning LSB-MSB. Displays the binary version of scan codes on LEDs on BASYS3 board and also displays the hexadecimal version of scan codes at BASYS3 7-segment display. Since BASYS3 doesn’t have a PS/2 input and creating a USB HID controller is impossible for me , there is built in micro controller on BASYS3 just below the USB port which mimics PS/2 input when there is USB.

  • VGA Display, takes the inputs from top module and tries to draw characters on the screen based on a algorithm, outputs are R,G,B and horizontal synch, vertical synch. It also has a submodule which synchronizes the BASYS 3 CLK with monitor.

  • Text operator, takes the input from Keyboard Analyzer and creates a string to do the shifting for vigenere technique. SystemVerilog do support string data-type but unfortunately Vivado software haven't implemented it yet. So I’ve used registers for creating strings. That’s why my strings have upper bound. I’ve defined an array of bytes, then assigned ASCII to each element then I had a constant with ASCII values in it that I can index into.

References:

Knowledge about PS/2 Port:

GNU GENERAL PUBLIC LICENSE