2014-01-29 03:51:02 -06:00
|
|
|
// test comment
|
|
|
|
/* test comment */
|
2013-09-14 04:23:45 -05:00
|
|
|
library(demo) {
|
2013-11-21 15:39:10 -06:00
|
|
|
cell(BUF) {
|
|
|
|
area: 6;
|
|
|
|
pin(A) { direction: input; }
|
|
|
|
pin(Y) { direction: output;
|
|
|
|
function: "A"; }
|
|
|
|
}
|
2013-09-14 04:23:45 -05:00
|
|
|
cell(NOT) {
|
|
|
|
area: 3;
|
|
|
|
pin(A) { direction: input; }
|
|
|
|
pin(Y) { direction: output;
|
|
|
|
function: "A'"; }
|
|
|
|
}
|
|
|
|
cell(NAND) {
|
|
|
|
area: 4;
|
|
|
|
pin(A) { direction: input; }
|
|
|
|
pin(B) { direction: input; }
|
|
|
|
pin(Y) { direction: output;
|
|
|
|
function: "(A*B)'"; }
|
|
|
|
}
|
|
|
|
cell(NOR) {
|
|
|
|
area: 4;
|
|
|
|
pin(A) { direction: input; }
|
|
|
|
pin(B) { direction: input; }
|
|
|
|
pin(Y) { direction: output;
|
|
|
|
function: "(A+B)'"; }
|
|
|
|
}
|
|
|
|
cell(DFF) {
|
|
|
|
area: 18;
|
|
|
|
ff(IQ, IQN) { clocked_on: C;
|
|
|
|
next_state: D; }
|
|
|
|
pin(C) { direction: input;
|
|
|
|
clock: true; }
|
|
|
|
pin(D) { direction: input; }
|
|
|
|
pin(Q) { direction: output;
|
|
|
|
function: "IQ"; }
|
|
|
|
}
|
2013-10-31 06:27:35 -05:00
|
|
|
cell(DFFSR) {
|
|
|
|
area: 18;
|
2015-07-06 10:45:56 -05:00
|
|
|
ff("IQ", "IQN") { clocked_on: C;
|
2013-10-31 06:27:35 -05:00
|
|
|
next_state: D;
|
|
|
|
preset: S;
|
|
|
|
clear: R; }
|
|
|
|
pin(C) { direction: input;
|
|
|
|
clock: true; }
|
|
|
|
pin(D) { direction: input; }
|
|
|
|
pin(Q) { direction: output;
|
|
|
|
function: "IQ"; }
|
|
|
|
pin(S) { direction: input; }
|
|
|
|
pin(R) { direction: input; }
|
2015-07-06 10:45:56 -05:00
|
|
|
; // empty statement
|
2013-10-31 06:27:35 -05:00
|
|
|
}
|
2013-09-14 04:23:45 -05:00
|
|
|
}
|