180 likes | 408 Views
Team M1 Enigma Machine Milestone 6 - 5 March, 2006. Adithya Attawar (M11) Shilpi Chakrabarti (M12) Zavo Gabriel (M13) Mike Sokolsky (M14). Design Manager: Prateek Goenka. Status. Finished: Behavioral Verilog and C simulation Structural Verilog Logic optimization
E N D
Team M1Enigma MachineMilestone 6 - 5 March, 2006 Adithya Attawar (M11) Shilpi Chakrabarti (M12) Zavo Gabriel (M13) Mike Sokolsky (M14) Design Manager: Prateek Goenka
Status • Finished: • Behavioral Verilog and C simulation • Structural Verilog • Logic optimization • Module-level spice delay and power simulations • Floorplan • In Progress: • Top-level schematic testing • Module layout • Todo: • Global Layout • Testing • Simulation
Design Decisions • Implement additional RSA encryption module • Optimization of floorplan for signal routing • Found adder was using un-buffered transmission gates to drive 6 gates. Doh! • Changed signal path to decrease number of muxes needed
Project Update • Quick look at the M4 Project • Found 3 original unbroken 4-wheel enigma messages • Example: • CLXP LWRU HCEY ZTCS OPUP PZDI UQRD LWXX FACT TJMB HDVC JJMM ZRPY IKHZ AWGL YXWT MJPQ UEFS ZBCT VRLA LZXW VXTS LFFF AUDQ FBWR RYAP SBOW JMKL DUYU PFUQ DOWV HAHC DWAU ARSW TXCF VOYF PUFH VZFD GGPO OVGR MBPX XZCA NKMO NFHX PCKH JZBU MXJW XKAU OD?Z UCVC XPFT CDXP LWRU VA • Using brute-force and hill climbing algorithms has broken one message using a distributed network of several hundred computers • Means even though it can be broken, it’s not very easy to do!!!!!!! (So you can send credit cards with it, right?) • Also means we have original cipher texts and settings to decode them! (Results coming next presentation)
Input Mux Mux Wheel Position Register N Reg C Reg Wheel Counters Adder % 26 ROM 26 X 5-bits RAM 26 X 5-bits ROM 206 X 5-bits Mux Wheel Order Reg Out Reg
Results of structural simulation 4000 creg:10 nreg: 1 rev:0 output:10 4100 creg:10 nreg: 8 rev:0 output:22 4200 creg:18 nreg: 3 rev:0 output:22 4300 creg:18 nreg: 3 rev:0 output:19 4400 creg:21 nreg: 6 rev:0 output:19 4500 creg:21 nreg: 2 rev:0 output: 8 4600 creg:23 nreg: 6 rev:0 output: 8 4700 creg: 7 nreg: 6 rev:1 output: 7 4800 creg: 7 nreg: 0 rev:1 output:23 4900 creg: 7 nreg: 3 rev:1 output:23 5000 creg: 7 nreg:19 rev:1 output:23 5100 creg: 0 nreg: 1 rev:1 output:23 5200 creg: 0 nreg:21 rev:1 output: 4 5300 creg:21 nreg: 1 rev:1 output: 4 5400 creg:21 nreg: 1 rev:1 output:21 5500 creg:10 nreg: 1 rev:1 output:21 5600 creg:10 nreg: 1 rev:1 output:21
Input Mux Mux Wheel Position Register P N Reg C Reg MULTIPLIER (loop E iterations) Wheel Counters E Adder % 26 ROM 26 X 5-bits RAM 26 X 5-bits D M ROM 206 X 5-bits MODULO (Divider) Mux Wheel Order Reg OUT Out Reg And the new module…
RSA Module Description • RSA encryption • 3 inputs: plaintext (5’b), modulus, exponent (12’b) • Result = PE % M • Take in a wheel initial position (5 bits), multiply it E times, and modulo M, output result (12 bits) • Repeat for all wheels used in Enigma encoding
RSA Module Status • Behavioral Verilog done, verified • Structural Verilog in progress • Goal: Choose multiplier design, done and verified by end of Spring Break • Schematics • Goal: Started by end of Spring Break
RSA Design Decisions • Basic FSM to control loading of P (from Enigma), E, and M (from off-chip), as well as looped multiply operation • Multiplier • Sequential is small, easy to implement • SLOW. Also requires nested counters (2 layers of loops) • Array multipliers are faster, more complex • Several interesting designs out there
Problems/Questions • Top level schematic still not verified • This should be taken care of in the next day or two • SRAM voltage problems in schematic simulation