Project - EE 421L
Braxon Tawatao
tawataob@unlv.nevada.edu
11/22/2014
Project - Part 1:
Schematic of the 8-bit ALU with 26 pins - In1(8), In2(8), S(2), Out(8):
data:image/s3,"s3://crabby-images/1d8b6/1d8b6bb3e7d4e536a9c74bb5ad5ef45f2c8d32c0" alt=""
For this ALU the 2 select bits can be used to choose an operation as follows:
S1 | S0 | Operation |
0 | 0 | In1 AND In2 |
0 | 1 | In1 OR In2 |
1 | 0 | In1 + In2 |
1 | 1 | In1 - In2 |
Corresponding symbol:
data:image/s3,"s3://crabby-images/b3631/b36315e2854c0c6ad7fce677961aadc083846005" alt=""
The ALU was simulated using the following schematic:
data:image/s3,"s3://crabby-images/b1e9f/b1e9fd4b7172e271ad603528938dc8278b045abb" alt=""
Simulation of AND operation:
data:image/s3,"s3://crabby-images/72549/725492067bbdb5ef65546334ed019712e62c8d95" alt=""
This
simulation illustrates 1111 1111 ANDed with 0000 001. The highlighted
outputs are all logic 0 while Out<0> is a logic 1.
Simulation of OR operation:
data:image/s3,"s3://crabby-images/983b2/983b2a98e56baf8b527748aa344e651c1472ba4c" alt=""
This
simulation illustrates 1000 0000 ORed with 0000 001. All of the highlighted
outputs are logic 0 while Out<0> and Out<7> are logic 1.
Simulation of 127 + 1 = 128 (unsigned in binary):
data:image/s3,"s3://crabby-images/839d4/839d46ea6a8099829b5572be197c4ab09016f964" alt=""
The result is 1000 0000 as expected. This demonstrates that carry of each FA functions correctly.
Simulation of 255 + 255 which causes an overflow and results in 1111 1110:
data:image/s3,"s3://crabby-images/a39cc/a39ccd56994711ca02a52e372c3461b96b84269f" alt=""
Simulation of 0 - (-1) = 0 + 1 = 1 (unsigned in binary):
data:image/s3,"s3://crabby-images/e404b/e404b5d98a6026b67c75a8064bbaf62f94658b50" alt=""
Only Out<0> is a logic 1 which is expected.
Simulation of -128 - 1 = -129 (which is an overflow) or 128 - 1 = 127 (unsigned in binary):
data:image/s3,"s3://crabby-images/e9050/e9050181aaf190d3b6577d979b5fc860235e580f" alt=""
The highlighted outputs are all logic 1 while Out<7> is a logic 0.
Backup of current project files:
data:image/s3,"s3://crabby-images/876e2/876e2b5378e32c1f79af6fe4a5b0aae975c9af80" alt=""
The Part 1 of the Project design directory can be found here.
Project - Part 2:
After re-evaluating my previous design, I realized that the use of 3 full-adders was quite inefficient.
I re-designed my 8-bit ALU to be the following circuit. This is version 2 of the 8-bit ALU:
Schematic:
data:image/s3,"s3://crabby-images/26c33/26c33b48b52b6869cc7b961d470b343e5ecc3b77" alt=""
Symbol:
data:image/s3,"s3://crabby-images/7ec84/7ec84e419340631b184774399504e607592afe87" alt=""
However, rather than creating a single layout for the entire ALU schematic, the ALU layout can be more efficiently completed by
instead
laying out a 1-bit ALU then cascading 8 of these blocks to create the
8-bit ALU layout. The final design was done in this way.
This is version 3 of the ALU:
1-bit ALU schematic:
data:image/s3,"s3://crabby-images/211c5/211c5689529d7a12a029bf7f78b9670c3d523b55" alt=""
1-bit symbol:
data:image/s3,"s3://crabby-images/2816c/2816cfc13e072fd792fc54561c6f8058acb54fcc" alt=""
Layout of the 1-bit ALU:
data:image/s3,"s3://crabby-images/487d4/487d43ddeff6203b495c5b32c2f2a20a05fc7c6a" alt=""
Layout passes DRC:
data:image/s3,"s3://crabby-images/d81c4/d81c4390055da88bbb19eea03b7e4a8f8a9b2cb9" alt=""
Layout passes LVS:
data:image/s3,"s3://crabby-images/b3300/b3300ddb190fd97e93ab8b3fadf5360fe36f9f59" alt=""
Using the 1-bit ALU, an 8-bit ALU can be made:
8-bit Schematic:
data:image/s3,"s3://crabby-images/a207e/a207e9e19cd66f0f28dc3bd590154fc14fda840f" alt=""
8-bit Symbol:
data:image/s3,"s3://crabby-images/b1d66/b1d6662196caffd5a841acfbb3732c2910ef8379" alt=""
Layout of the 8-bit ALU. Layout also passes LVS:
data:image/s3,"s3://crabby-images/9535c/9535cfc3bb6125cbbc185702404040580c2e6133" alt=""
Layout passes DRC:
data:image/s3,"s3://crabby-images/ea775/ea7756063f05a68dee6453ce67b5c9f7c16ad721" alt=""
Backup of project files:
data:image/s3,"s3://crabby-images/04f03/04f033ea87b511ca30f30f36365de5a6b89bdb38" alt=""
The entire Project design directory can be found here.
The cells that have "v3" appended to their titles consist of the final design.
Return to labs