74181

Teile dieses Themas wurden möglicherweise maschinell übersetzt.

Die 74181-Schaltung ist eine 4-Bit-ALU.

Verilog-Äquivalent, befasst sich nicht mit Ausführen usw.:

Modul Alu74181(
Eingabe [3:0]s,
Eingabe ci, M,
Eingabe [3:0] a, b,
Ausgabereg [3:0] y
);

reg [3:0] p, g;

immer @(*) beginnen

p[0] <= ~(a[0] | (s[0] & b[0]) | (s[1] & ~b[0]));
p[1] <= ~(a[1] | (s[0] & b[1]) | (s[1] & ~b[1]));
p[2] <= ~(a[2] | (s[0] & b[2]) | (s[1] & ~b[2]));
p[3] <= ~(a[3] | (s[0] & b[3]) | (s[1] & ~b[3]));

g[0] <= ~((a[0] & ~b[0] & s[2]) | (a[0] & b[0] & s[3]));
g[1] <= ~((a[1] & ~b[1] & s[2]) | (a[1] & b[1] & s[3]));
g[2] <= ~((a[2] & ~b[2] & s[2]) | (a[2] & b[2] & s[3]));
g[3] <= ~((a[3] & ~b[3] & s[2]) | (a[3] & b[3] & s[3]));

y[0] = (p[0] ^ g[0]) ^ ~(~ci & ~M);
y[1] = (p[1] ^ g[1]) ^ ~((~ci & ~M & g[0]) | (~M & p[0]));
y[2] = (p[2] ^ g[2]) ^ ~((~ci & ~M & g[0] & g[1]) | (~M & p[1]) | (~M & p[0] & g[1]));
y[3] = (p[3] ^ g[3]) ^ ~((~ci & ~M & g[0] & g[1] & g[2]) | (~M & p[2] ) |. (~M & p[1] & g[2]) | (~M & p[0] & g[1] & g[2]));
Ende
Endmodul // alu74181
Zurück
Lizenziert unter CC-BY-NC-SA. Zuletzt bearbeitet am : 2024-10-04 17:19:52