Create an 8-bit version of the
74x382 ALU
|
|
This code makes
it easy to verify the functionality of the ALU -- "How to
use" -- Download the .bit file to your kit and try:
1)
If the leftmost Dp and
Dig1:0 (the rightmost) flashes
does it mean that you can define A(7:0) with the
Sw(7:0)
Press <Btn1> in order to update => A = Dig1:0 = Dig3:2
2)
Press <Btn0> in
order to change input "Valg"
3)
If the next leftmost Dp and Dig1:0 (the rightmost) flashes
does it mean that you can define B(7:0) with the
Sw(7:0)
Press <Btn1> in order to update => B = Dig1:0 = Dig3:2
4)
Press <Btn0> again in order to change "Valg" for arithmetic
5)
When Dig3 flashes for arithmetic mode.
Use <Btn3> and <Btn2> to select S = 0..7
Use <Btn1> to toggle the Cin (watch Dp0)
6)
Press <Btn0> to start the process of watch/change A,B
|
|
|
|
Last updated:
22-02-09 |
data:image/s3,"s3://crabby-images/3208e/3208e4149ee0501b418ac2fcc7662999d09024af" alt=""
|
Function table for the
ALU_DESIGN |
S2 S1 S0 |
Function |
Cout |
0 0
0 |
F =
0000 |
0 |
0 0
1 |
F = B - A - 1 + Cin
|
F(8) |
0 1
0 |
F = A - B - 1 + Cin |
F(8) |
0 1
1 |
F = A + B + Cin |
F(8) |
1 0
0 |
F = A xor B |
not Cin |
1 0
1 |
F = A or B |
Cin |
1 1
0 |
F = A and B |
Cin |
1 1
1 |
F = 1111 |
1 |
|
|
|
|
|
data:image/s3,"s3://crabby-images/a9d4a/a9d4aa76c0abdd9015efdc73c5d809cc22d58cef" alt=""
|
Please note!
You doesn't have to understand the code below in
order to solve the task.
|
|
data:image/s3,"s3://crabby-images/1dd58/1dd5822ccc31d7147949ed302f3fe1408e22e224" alt="" |
data:image/s3,"s3://crabby-images/3208e/3208e4149ee0501b418ac2fcc7662999d09024af" alt="" |
data:image/s3,"s3://crabby-images/124e4/124e4f73afba118a83711fa8b7df90b87237d3ff" alt="" |
data:image/s3,"s3://crabby-images/98c40/98c40d0209b029c70136303b25265e80782f987e" alt="" |
The purpose of
this function will be the switch among the various
data for display.
Please note how "Valg" used.
The Clk_1Hz can be
used for the Flashing effect.
This signal will be 0 for say 500 msec and 1 for 500
msec.
The Blanking bits
do the trick.
|
data:image/s3,"s3://crabby-images/38d93/38d9321c8927288fc0d195df88df5df26493161e" alt="" |
The basic idea in
this process is the implementation of a debouche
functionality and the ability of edge-detection of
more the on input.
This makes it
possible to increment, decrement and load values at
the same variables/signals.
|
|
data:image/s3,"s3://crabby-images/75aa2/75aa202e86e5068040be78702c64aa0e71babb02" alt="" |
|
|
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/a4c94/a4c9442f55e3b83ebcd7e37a21851b90305736e4" alt="" |
data:image/s3,"s3://crabby-images/f588d/f588d0c299040eac588ca7e3238934ef4c0af3e5" alt="" |
|
|
data:image/s3,"s3://crabby-images/13687/13687f249f430edfe92ef7689704361508b4626e" alt="" |
data:image/s3,"s3://crabby-images/be22a/be22aa867c86447986c0aaf6dcb1570bdd2bb329" alt="" |
|
|
data:image/s3,"s3://crabby-images/3e568/3e56825a1a7a79a61b1d23f239668a0a45bbcce0" alt="" |
data:image/s3,"s3://crabby-images/4411f/4411f0b4b2299d02d678d8a3543cd4a591ddb7f9" alt="" |
|
|
data:image/s3,"s3://crabby-images/cb355/cb355eece9ae87f741e211779dd2f159b653dbb7" alt="" |
data:image/s3,"s3://crabby-images/5d021/5d021147244bb20b7f4061e7b74cb4a47567995b" alt="" |
|
|
This how it's done in
9.2i -
The text editor chosen automatically in 10.1i |
Mark a field of text
and use the Comment / Uncomment commands
|
|
|
|
|
|
|