The 8-bit adder has been already covered in the early stages of the design and I found a satisfying diagram/circuit which, though not perfectly perfect, is 95% or so. And it works.
As already mentioned in an early log, I targeted the structure around the Actel ProASIC3 family that uses 3-input tiles. This makes it practical to build Carry Lookahead blocks/units with 3 "bits" of input, and since 3×3=9, it perfectly fits the width of the required 8 bits of data plus the Carry Out flag:
data:image/s3,"s3://crabby-images/1be6e/1be6e9f88d39c573212f65404021568845682bb4" alt=""
The adder gets the P, G and X inputs from the Logic unit (which is tightly bound). The first bits look like this :
data:image/s3,"s3://crabby-images/0c48b/0c48ba5ff56fe357a28852a9fd01b885277c016a" alt=""
We already notice a recurring circuit made of OR3,AND2,AND3:
data:image/s3,"s3://crabby-images/8e289/8e2899f6d34370d151efcc819dd9dde0468db2bb" alt=""
This sub-circuit will be a good target for optimisation at ASIC level for example.
Chaining the first CLA3 with the second one gives the following diagram:
data:image/s3,"s3://crabby-images/56617/56617dddfd33774e09d1f2416633a30b9a31a270" alt=""
The logic depth is already 6 gates, not even counting the layer for P and G in the logic unit. There are already 4 "A2A3O3" circuits.
Adding the last bit and the carry out requires some care but doesn't increase the logic depth if some parts of the last A2A3O3 are moved closer to the inputs.
data:image/s3,"s3://crabby-images/c3ec8/c3ec8c30333b7a40b37be87f0db8b91a888d3446" alt=""
The fan-in and fanout have been carefully balanced, the maximum is Cin with a fan-in of 5 in the critical datapath. This ensure a reasonable speed for ASIC and FPGA.
There are 25 "tiles" (an average of 3 gates per bit to compute the lookahead) plus 9 XOR, so we must allocate at least 4 tiles per bit for the place&route.
5 instances of A2A3O3 can be pre-routed, leaving 7 other gates to place. These 5 instances can be replaced by the following combo for ASIC:
data:image/s3,"s3://crabby-images/81c72/81c72d85da4e43e7ef7556972b8cd41d3a078275" alt=""
Discussions
Become a Hackaday.io Member
Create an account to leave a comment. Already have an account? Log In.