2 * Copyright (c) 2003 Stephen Williams (steve at icarus.com)
4 * This source code is free software; you can redistribute it
5 * and/or modify it in source code form under the terms of the GNU
6 * General Public License as published by the Free Software
7 * Foundation; either version 2 of the License, or (at your option)
10 * This program is distributed in the hope that it will be useful,
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 * GNU General Public License for more details.
15 * You should have received a copy of the GNU General Public License
16 * along with this program; if not, write to the Free Software
17 * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA
20 #ident "$Id: xilinx.c,v 1.13 2007/02/26 19:49:50 steve Exp $"
26 # include "fpga_priv.h"
34 edif_cell_t
xilinx_cell_buf(edif_xlibrary_t xlib
)
36 static edif_cell_t cell
= 0;
37 if (cell
) return cell
;
39 cell
= edif_xcell_create(xlib
, "BUF", 2);
40 edif_cell_portconfig(cell
, BUF_O
, "O", IVL_SIP_OUTPUT
);
41 edif_cell_portconfig(cell
, BUF_I
, "I", IVL_SIP_INPUT
);
45 edif_cell_t
xilinx_cell_bufe(edif_xlibrary_t xlib
)
47 static edif_cell_t cell
= 0;
48 if (cell
) return cell
;
50 cell
= edif_xcell_create(xlib
, "BUFE", 3);
51 edif_cell_portconfig(cell
, BUF_O
, "O", IVL_SIP_OUTPUT
);
52 edif_cell_portconfig(cell
, BUF_I
, "I", IVL_SIP_INPUT
);
53 edif_cell_portconfig(cell
, BUF_T
, "E", IVL_SIP_INPUT
);
57 edif_cell_t
xilinx_cell_bufg(edif_xlibrary_t xlib
)
59 static edif_cell_t cell
= 0;
60 if (cell
) return cell
;
62 cell
= edif_xcell_create(xlib
, "BUFG", 2);
63 edif_cell_portconfig(cell
, BUF_O
, "O", IVL_SIP_OUTPUT
);
64 edif_cell_portconfig(cell
, BUF_I
, "I", IVL_SIP_INPUT
);
68 edif_cell_t
xilinx_cell_buft(edif_xlibrary_t xlib
)
70 static edif_cell_t cell
= 0;
71 if (cell
) return cell
;
73 cell
= edif_xcell_create(xlib
, "BUFT", 3);
74 edif_cell_portconfig(cell
, BUF_O
, "O", IVL_SIP_OUTPUT
);
75 edif_cell_portconfig(cell
, BUF_I
, "I", IVL_SIP_INPUT
);
76 edif_cell_portconfig(cell
, BUF_T
, "T", IVL_SIP_INPUT
);
80 edif_cell_t
xilinx_cell_ibuf(edif_xlibrary_t xlib
)
82 static edif_cell_t cell
= 0;
83 if (cell
) return cell
;
85 cell
= edif_xcell_create(xlib
, "IBUF", 2);
86 edif_cell_portconfig(cell
, BUF_O
, "O", IVL_SIP_OUTPUT
);
87 edif_cell_portconfig(cell
, BUF_I
, "I", IVL_SIP_INPUT
);
91 edif_cell_t
xilinx_cell_inv(edif_xlibrary_t xlib
)
93 static edif_cell_t cell
= 0;
94 if (cell
) return cell
;
96 cell
= edif_xcell_create(xlib
, "INV", 2);
97 edif_cell_portconfig(cell
, BUF_O
, "O", IVL_SIP_OUTPUT
);
98 edif_cell_portconfig(cell
, BUF_I
, "I", IVL_SIP_INPUT
);
102 edif_cell_t
xilinx_cell_muxf5(edif_xlibrary_t xlib
)
104 static edif_cell_t cell
= 0;
105 if (cell
) return cell
;
107 cell
= edif_xcell_create(xlib
, "MUXF5", 4);
108 edif_cell_portconfig(cell
, MUXF_O
, "O", IVL_SIP_OUTPUT
);
109 edif_cell_portconfig(cell
, MUXF_I0
, "I0", IVL_SIP_INPUT
);
110 edif_cell_portconfig(cell
, MUXF_I1
, "I1", IVL_SIP_INPUT
);
111 edif_cell_portconfig(cell
, MUXF_S
, "S", IVL_SIP_INPUT
);
115 edif_cell_t
xilinx_cell_muxf6(edif_xlibrary_t xlib
)
117 static edif_cell_t cell
= 0;
118 if (cell
) return cell
;
120 cell
= edif_xcell_create(xlib
, "MUXF6", 4);
121 edif_cell_portconfig(cell
, MUXF_O
, "O", IVL_SIP_OUTPUT
);
122 edif_cell_portconfig(cell
, MUXF_I0
, "I0", IVL_SIP_INPUT
);
123 edif_cell_portconfig(cell
, MUXF_I1
, "I1", IVL_SIP_INPUT
);
124 edif_cell_portconfig(cell
, MUXF_S
, "S", IVL_SIP_INPUT
);
128 edif_cell_t
xilinx_cell_obuf(edif_xlibrary_t xlib
)
130 static edif_cell_t cell
= 0;
131 if (cell
) return cell
;
133 cell
= edif_xcell_create(xlib
, "OBUF", 2);
134 edif_cell_portconfig(cell
, BUF_O
, "O", IVL_SIP_OUTPUT
);
135 edif_cell_portconfig(cell
, BUF_I
, "I", IVL_SIP_INPUT
);
140 edif_cell_t
xilinx_cell_lut2(edif_xlibrary_t xlib
)
142 static edif_cell_t cell
= 0;
143 if (cell
!= 0) return cell
;
145 cell
= edif_xcell_create(xlib
, "LUT2", 3);
146 edif_cell_portconfig(cell
, LUT_O
, "O", IVL_SIP_OUTPUT
);
147 edif_cell_portconfig(cell
, LUT_I0
, "I0", IVL_SIP_INPUT
);
148 edif_cell_portconfig(cell
, LUT_I1
, "I1", IVL_SIP_INPUT
);
152 edif_cell_t
xilinx_cell_lut3(edif_xlibrary_t xlib
)
154 static edif_cell_t cell
= 0;
155 if (cell
!= 0) return cell
;
157 cell
= edif_xcell_create(xlib
, "LUT3", 4);
158 edif_cell_portconfig(cell
, LUT_O
, "O", IVL_SIP_OUTPUT
);
159 edif_cell_portconfig(cell
, LUT_I0
, "I0", IVL_SIP_INPUT
);
160 edif_cell_portconfig(cell
, LUT_I1
, "I1", IVL_SIP_INPUT
);
161 edif_cell_portconfig(cell
, LUT_I2
, "I2", IVL_SIP_INPUT
);
165 edif_cell_t
xilinx_cell_lut4(edif_xlibrary_t xlib
)
167 static edif_cell_t cell
= 0;
168 if (cell
!= 0) return cell
;
170 cell
= edif_xcell_create(xlib
, "LUT4", 5);
171 edif_cell_portconfig(cell
, LUT_O
, "O", IVL_SIP_OUTPUT
);
172 edif_cell_portconfig(cell
, LUT_I0
, "I0", IVL_SIP_INPUT
);
173 edif_cell_portconfig(cell
, LUT_I1
, "I1", IVL_SIP_INPUT
);
174 edif_cell_portconfig(cell
, LUT_I2
, "I2", IVL_SIP_INPUT
);
175 edif_cell_portconfig(cell
, LUT_I3
, "I3", IVL_SIP_INPUT
);
180 edif_cell_t
xilinx_cell_fdce(edif_xlibrary_t xlib
)
182 static edif_cell_t cell
= 0;
183 if (cell
!= 0) return cell
;
185 cell
= edif_xcell_create(xlib
, "FDCE", 5);
186 edif_cell_portconfig(cell
, FDCE_Q
, "Q", IVL_SIP_OUTPUT
);
187 edif_cell_portconfig(cell
, FDCE_D
, "D", IVL_SIP_INPUT
);
188 edif_cell_portconfig(cell
, FDCE_C
, "C", IVL_SIP_INPUT
);
189 edif_cell_portconfig(cell
, FDCE_CE
, "CE", IVL_SIP_INPUT
);
190 edif_cell_portconfig(cell
, FDCE_CLR
,"CLR", IVL_SIP_INPUT
);
194 edif_cell_t
xilinx_cell_fdcpe(edif_xlibrary_t xlib
)
196 static edif_cell_t cell
= 0;
197 if (cell
!= 0) return cell
;
199 cell
= edif_xcell_create(xlib
, "FDCPE", 6);
200 edif_cell_portconfig(cell
, FDCE_Q
, "Q", IVL_SIP_OUTPUT
);
201 edif_cell_portconfig(cell
, FDCE_D
, "D", IVL_SIP_INPUT
);
202 edif_cell_portconfig(cell
, FDCE_C
, "C", IVL_SIP_INPUT
);
203 edif_cell_portconfig(cell
, FDCE_CE
, "CE", IVL_SIP_INPUT
);
204 edif_cell_portconfig(cell
, FDCE_CLR
,"CLR", IVL_SIP_INPUT
);
205 edif_cell_portconfig(cell
, FDCE_PRE
,"PRE", IVL_SIP_INPUT
);
209 edif_cell_t
xilinx_cell_fdre(edif_xlibrary_t xlib
)
211 static edif_cell_t cell
= 0;
212 if (cell
!= 0) return cell
;
214 cell
= edif_xcell_create(xlib
, "FDRE", 5);
215 edif_cell_portconfig(cell
, FDCE_Q
, "Q", IVL_SIP_OUTPUT
);
216 edif_cell_portconfig(cell
, FDCE_D
, "D", IVL_SIP_INPUT
);
217 edif_cell_portconfig(cell
, FDCE_C
, "C", IVL_SIP_INPUT
);
218 edif_cell_portconfig(cell
, FDCE_CE
, "CE", IVL_SIP_INPUT
);
219 edif_cell_portconfig(cell
, FDCE_CLR
,"R", IVL_SIP_INPUT
);
224 edif_cell_t
xilinx_cell_mult_and(edif_xlibrary_t xlib
)
226 static edif_cell_t cell
= 0;
227 if (cell
!= 0) return cell
;
229 cell
= edif_xcell_create(xlib
, "MULT_AND", 3);
230 edif_cell_portconfig(cell
, MULT_AND_LO
, "LO", IVL_SIP_OUTPUT
);
231 edif_cell_portconfig(cell
, MULT_AND_I0
, "I0", IVL_SIP_INPUT
);
232 edif_cell_portconfig(cell
, MULT_AND_I1
, "I1", IVL_SIP_INPUT
);
236 edif_cell_t
xilinx_cell_muxcy(edif_xlibrary_t xlib
)
238 static edif_cell_t cell
= 0;
239 if (cell
!= 0) return cell
;
241 cell
= edif_xcell_create(xlib
, "MUXCY", 4);
242 edif_cell_portconfig(cell
, MUXCY_O
, "O", IVL_SIP_OUTPUT
);
243 edif_cell_portconfig(cell
, MUXCY_DI
, "DI", IVL_SIP_INPUT
);
244 edif_cell_portconfig(cell
, MUXCY_CI
, "CI", IVL_SIP_INPUT
);
245 edif_cell_portconfig(cell
, MUXCY_S
, "S", IVL_SIP_INPUT
);
249 edif_cell_t
xilinx_cell_muxcy_l(edif_xlibrary_t xlib
)
251 static edif_cell_t cell
= 0;
252 if (cell
!= 0) return cell
;
254 cell
= edif_xcell_create(xlib
, "MUXCY_L", 4);
255 edif_cell_portconfig(cell
, MUXCY_O
, "LO", IVL_SIP_OUTPUT
);
256 edif_cell_portconfig(cell
, MUXCY_DI
, "DI", IVL_SIP_INPUT
);
257 edif_cell_portconfig(cell
, MUXCY_CI
, "CI", IVL_SIP_INPUT
);
258 edif_cell_portconfig(cell
, MUXCY_S
, "S", IVL_SIP_INPUT
);
262 edif_cell_t
xilinx_cell_xorcy(edif_xlibrary_t xlib
)
264 static edif_cell_t cell
= 0;
265 if (cell
!= 0) return cell
;
267 cell
= edif_xcell_create(xlib
, "XORCY", 3);
268 edif_cell_portconfig(cell
, XORCY_O
, "O", IVL_SIP_OUTPUT
);
269 edif_cell_portconfig(cell
, XORCY_CI
, "CI", IVL_SIP_INPUT
);
270 edif_cell_portconfig(cell
, XORCY_LI
, "LI", IVL_SIP_INPUT
);
275 * This function does a lot of the stuff common to the header
276 * functions of various Xilinx families. This includes creating the edf
277 * object that holds the netlist.
279 void xilinx_common_header(ivl_design_t des
)
282 ivl_scope_t root
= ivl_design_root(des
);
283 unsigned sig_cnt
= ivl_scope_sigs(root
);
284 unsigned nports
= 0, pidx
;
286 /* Count the ports I'm going to use. */
287 for (idx
= 0 ; idx
< sig_cnt
; idx
+= 1) {
288 ivl_signal_t sig
= ivl_scope_sig(root
, idx
);
290 if (ivl_signal_port(sig
) == IVL_SIP_NONE
)
293 if (ivl_signal_attr(sig
, "PAD") != 0)
296 nports
+= ivl_signal_pins(sig
);
299 edf
= edif_create(ivl_scope_basename(root
), nports
);
302 for (idx
= 0 ; idx
< sig_cnt
; idx
+= 1) {
304 ivl_signal_t sig
= ivl_scope_sig(root
, idx
);
306 if (ivl_signal_port(sig
) == IVL_SIP_NONE
)
309 if (ivl_signal_attr(sig
, "PAD") != 0)
312 if (ivl_signal_pins(sig
) == 1) {
313 edif_portconfig(edf
, pidx
, ivl_signal_basename(sig
),
314 ivl_signal_port(sig
));
316 assert(ivl_signal_pins(sig
) == 1);
317 jnt
= edif_joint_of_nexus(edf
, ivl_signal_pin(sig
, 0));
318 edif_port_to_joint(jnt
, edf
, pidx
);
321 const char*name
= ivl_signal_basename(sig
);
322 ivl_signal_port_t dir
= ivl_signal_port(sig
);
325 for (bit
= 0 ; bit
< ivl_signal_pins(sig
) ; bit
+= 1) {
327 sprintf(buf
, "%s[%u]", name
, bit
);
329 edif_portconfig(edf
, pidx
+bit
, tmp
, dir
);
331 jnt
= edif_joint_of_nexus(edf
,ivl_signal_pin(sig
,bit
));
332 edif_port_to_joint(jnt
, edf
, pidx
+bit
);
336 pidx
+= ivl_signal_pins(sig
);
339 assert(pidx
== nports
);
342 void xilinx_show_footer(ivl_design_t des
)
346 for (idx
= 0 ; idx
< ivl_design_consts(des
) ; idx
+= 1) {
348 ivl_net_const_t net
= ivl_design_const(des
, idx
);
349 const char*val
= ivl_const_bits(net
);
351 for (pin
= 0 ; pin
< ivl_const_pins(net
) ; pin
+= 1) {
355 jnt
= edif_joint_of_nexus(edf
, ivl_const_pin(net
, pin
));
358 pad
= edif_cellref_create(edf
, cell_0
);
361 pad
= edif_cellref_create(edf
, cell_1
);
368 edif_add_to_joint(jnt
, pad
, 0);
372 edif_print(xnf
, edf
);
376 * Make (or retrieve) a cell in the external library that reflects the
377 * scope with its ports.
379 void xilinx_show_scope(ivl_scope_t scope
)
386 cell
= edif_xlibrary_scope_cell(xlib
, scope
);
387 ref
= edif_cellref_create(edf
, cell
);
389 for (idx
= 0 ; idx
< ivl_scope_sigs(scope
) ; idx
+= 1) {
391 ivl_signal_t sig
= ivl_scope_sig(scope
, idx
);
393 if (ivl_signal_port(sig
) == IVL_SIP_NONE
)
396 port
= edif_cell_port_byname(cell
, ivl_signal_basename(sig
));
397 jnt
= edif_joint_of_nexus(edf
, ivl_signal_pin(sig
, 0));
398 edif_add_to_joint(jnt
, ref
, port
);
402 void xilinx_pad(ivl_signal_t sig
, const char*str
)
407 if (cell_ipad
== 0) {
408 cell_ipad
= edif_xcell_create(xlib
, "IPAD", 1);
409 edif_cell_portconfig(cell_ipad
, 0, "IPAD", IVL_SIP_OUTPUT
);
412 if (cell_opad
== 0) {
413 cell_opad
= edif_xcell_create(xlib
, "OPAD", 1);
414 edif_cell_portconfig(cell_opad
, 0, "OPAD", IVL_SIP_INPUT
);
417 if (cell_iopad
== 0) {
418 cell_iopad
= edif_xcell_create(xlib
, "IOPAD", 1);
419 edif_cell_portconfig(cell_iopad
, 0, "IOPAD", IVL_SIP_INOUT
);
422 /* Collect an array of pin assignments from the attribute
423 string passed in as str. The format is a comma separated
424 list of location names. */
425 pins
= calloc(ivl_signal_pins(sig
), sizeof(char*));
426 for (idx
= 0 ; idx
< ivl_signal_pins(sig
) ; idx
+= 1) {
427 const char*tmp
= strchr(str
, ',');
428 if (tmp
== 0) tmp
= str
+strlen(str
);
430 pins
[idx
] = malloc(tmp
-str
+1);
431 strncpy(pins
[idx
], str
, tmp
-str
);
432 pins
[idx
][tmp
-str
] = 0;
440 /* Now go through the pins of the signal, creating pads and
441 bufs and joining them to the signal nexus. */
442 for (idx
= 0 ; idx
< ivl_signal_pins(sig
) ; idx
+= 1) {
444 edif_cellref_t pad
, buf
;
446 const char*name_str
= ivl_signal_basename(sig
);
447 if (ivl_signal_pins(sig
) > 1) {
449 sprintf(name_buf
, "%s[%u]", name_str
, idx
);
450 name_str
= strdup(name_buf
);
453 switch (ivl_signal_port(sig
)) {
455 pad
= edif_cellref_create(edf
, cell_ipad
);
456 buf
= edif_cellref_create(edf
, xilinx_cell_ibuf(xlib
));
458 jnt
= edif_joint_create(edf
);
459 edif_joint_rename(jnt
, name_str
);
460 edif_add_to_joint(jnt
, pad
, 0);
461 edif_add_to_joint(jnt
, buf
, BUF_I
);
463 jnt
= edif_joint_of_nexus(edf
, ivl_signal_pin(sig
, idx
));
464 edif_add_to_joint(jnt
, buf
, BUF_O
);
468 pad
= edif_cellref_create(edf
, cell_opad
);
469 buf
= edif_cellref_create(edf
, xilinx_cell_obuf(xlib
));
471 jnt
= edif_joint_create(edf
);
472 edif_joint_rename(jnt
, name_str
);
473 edif_add_to_joint(jnt
, pad
, 0);
474 edif_add_to_joint(jnt
, buf
, BUF_O
);
476 jnt
= edif_joint_of_nexus(edf
, ivl_signal_pin(sig
, idx
));
477 edif_add_to_joint(jnt
, buf
, BUF_I
);
481 pad
= edif_cellref_create(edf
, cell_iopad
);
483 jnt
= edif_joint_of_nexus(edf
, ivl_signal_pin(sig
, idx
));
484 edif_add_to_joint(jnt
, pad
, 0);
492 edif_cellref_pstring(pad
, "LOC", pins
[idx
]);
496 /* Don't free the allocated pad name strings. The
497 edif_cellref_pstring function attached the string to the
498 LOC attribute, so the reference is permanent. */
504 * This function handles the case where the user specifies the cell to
507 static void edif_cellref_logic(ivl_net_logic_t net
, const char*def
)
509 char*str
= strdup(def
);
516 pins
= strchr(str
, ':');
520 /* Locate the cell in the library, lookup by name. */
521 cell
= edif_xlibrary_findcell(xlib
, str
);
524 ref
= edif_cellref_create(edf
, cell
);
526 for (idx
= 0 ; idx
< ivl_logic_pins(net
) ; idx
+= 1) {
530 tmp
= strchr(pins
,',');
536 port
= edif_cell_port_byname(cell
, pins
);
537 jnt
= edif_joint_of_nexus(edf
, ivl_logic_pin(net
, idx
));
538 edif_add_to_joint(jnt
, ref
, port
);
546 static void lut_logic(ivl_net_logic_t net
, const char*init3
,
547 const char*init4
, const char*init5
)
549 edif_cellref_t lut
= NULL
; /* initialization shuts up gcc -Wall */
551 const char* init
= NULL
; /* ditto */
553 assert(ivl_logic_pins(net
) <= 5);
554 assert(ivl_logic_pins(net
) >= 3);
556 switch (ivl_logic_pins(net
)) {
558 lut
= edif_cellref_create(edf
, xilinx_cell_lut2(xlib
));
563 lut
= edif_cellref_create(edf
, xilinx_cell_lut3(xlib
));
568 lut
= edif_cellref_create(edf
, xilinx_cell_lut4(xlib
));
573 edif_cellref_pstring(lut
, "INIT", init
);
575 switch (ivl_logic_pins(net
)) {
577 jnt
= edif_joint_of_nexus(edf
, ivl_logic_pin(net
, 4));
578 edif_add_to_joint(jnt
, lut
, LUT_I3
);
580 jnt
= edif_joint_of_nexus(edf
, ivl_logic_pin(net
, 3));
581 edif_add_to_joint(jnt
, lut
, LUT_I2
);
583 jnt
= edif_joint_of_nexus(edf
, ivl_logic_pin(net
, 2));
584 edif_add_to_joint(jnt
, lut
, LUT_I1
);
587 jnt
= edif_joint_of_nexus(edf
, ivl_logic_pin(net
, 1));
588 edif_add_to_joint(jnt
, lut
, LUT_I0
);
590 jnt
= edif_joint_of_nexus(edf
, ivl_logic_pin(net
, 0));
591 edif_add_to_joint(jnt
, lut
, LUT_O
);
595 void xilinx_logic(ivl_net_logic_t net
)
600 { const char*cellref_attribute
= ivl_logic_attr(net
, "cellref");
601 if (cellref_attribute
!= 0) {
602 edif_cellref_logic(net
, cellref_attribute
);
607 switch (ivl_logic_type(net
)) {
611 assert(ivl_logic_pins(net
) == 2);
613 obj
= edif_cellref_create(edf
, xilinx_cell_buf(xlib
));
615 jnt
= edif_joint_of_nexus(edf
, ivl_logic_pin(net
, 0));
616 edif_add_to_joint(jnt
, obj
, BUF_O
);
618 jnt
= edif_joint_of_nexus(edf
, ivl_logic_pin(net
, 1));
619 edif_add_to_joint(jnt
, obj
, BUF_I
);
623 /* The Xilinx BUFT devices is a BUF that adds a T
624 input. The output is tri-stated if the T input is
625 1. In other words, it acts just like bufif0. */
626 assert(ivl_logic_pins(net
) == 3);
628 obj
= edif_cellref_create(edf
, xilinx_cell_buft(xlib
));
630 jnt
= edif_joint_of_nexus(edf
, ivl_logic_pin(net
, 0));
631 edif_add_to_joint(jnt
, obj
, BUF_O
);
633 jnt
= edif_joint_of_nexus(edf
, ivl_logic_pin(net
, 1));
634 edif_add_to_joint(jnt
, obj
, BUF_I
);
636 jnt
= edif_joint_of_nexus(edf
, ivl_logic_pin(net
, 2));
637 edif_add_to_joint(jnt
, obj
, BUF_T
);
641 /* The Xilinx BUFE devices is a BUF that adds an enable
642 input. The output is tri-stated if the E input is 0.
643 In other words, it acts just like bufif1. */
644 assert(ivl_logic_pins(net
) == 3);
646 obj
= edif_cellref_create(edf
, xilinx_cell_bufe(xlib
));
648 jnt
= edif_joint_of_nexus(edf
, ivl_logic_pin(net
, 0));
649 edif_add_to_joint(jnt
, obj
, BUF_O
);
651 jnt
= edif_joint_of_nexus(edf
, ivl_logic_pin(net
, 1));
652 edif_add_to_joint(jnt
, obj
, BUF_I
);
654 jnt
= edif_joint_of_nexus(edf
, ivl_logic_pin(net
, 2));
655 edif_add_to_joint(jnt
, obj
, BUF_T
);
659 assert(ivl_logic_pins(net
) == 2);
661 obj
= edif_cellref_create(edf
, xilinx_cell_inv(xlib
));
663 jnt
= edif_joint_of_nexus(edf
, ivl_logic_pin(net
, 0));
664 edif_add_to_joint(jnt
, obj
, BUF_O
);
666 jnt
= edif_joint_of_nexus(edf
, ivl_logic_pin(net
, 1));
667 edif_add_to_joint(jnt
, obj
, BUF_I
);
671 assert(ivl_logic_pins(net
) <= 5);
672 assert(ivl_logic_pins(net
) >= 3);
673 lut_logic(net
, "8", "80", "8000");
677 assert(ivl_logic_pins(net
) <= 5);
678 assert(ivl_logic_pins(net
) >= 3);
679 lut_logic(net
, "1", "01", "0001");
683 assert(ivl_logic_pins(net
) <= 5);
684 assert(ivl_logic_pins(net
) >= 3);
685 lut_logic(net
, "E", "FE", "FFFE");
689 assert(ivl_logic_pins(net
) <= 5);
690 assert(ivl_logic_pins(net
) >= 3);
691 lut_logic(net
, "9", "69", "9669");
695 assert(ivl_logic_pins(net
) <= 5);
696 assert(ivl_logic_pins(net
) >= 3);
697 lut_logic(net
, "6", "96", "6996");
701 fprintf(stderr
, "UNSUPPORTED LOGIC TYPE: %u\n",
702 ivl_logic_type(net
));
708 * A fully generic Xilinx MUX is implemented entirely from LUT
711 void xilinx_mux(ivl_lpm_t net
)
718 assert(ivl_lpm_selects(net
) == 1);
720 /* A/B Mux devices are made from LUT3 devices. I0 is connected
721 to A, I1 to B, and I2 to the Select input. Create as many
722 as are needed to implement the requested width.
737 for (idx
= 0 ; idx
< ivl_lpm_width(net
) ; idx
+= 1) {
739 lut
= edif_cellref_create(edf
, xilinx_cell_lut3(xlib
));
741 jnt
= edif_joint_of_nexus(edf
, ivl_lpm_q(net
, idx
));
742 edif_add_to_joint(jnt
, lut
, LUT_O
);
744 jnt
= edif_joint_of_nexus(edf
, ivl_lpm_data2(net
, 0, idx
));
745 edif_add_to_joint(jnt
, lut
, LUT_I0
);
747 jnt
= edif_joint_of_nexus(edf
, ivl_lpm_data2(net
, 1, idx
));
748 edif_add_to_joint(jnt
, lut
, LUT_I1
);
750 jnt
= edif_joint_of_nexus(edf
, ivl_lpm_select(net
, 0));
751 edif_add_to_joint(jnt
, lut
, LUT_I2
);
753 edif_cellref_pstring(lut
, "INIT", "CA");
758 * Any Xilinx device works with this adder.
759 * Generic Xilinx add only works for single bit slices.
761 void xilinx_add(ivl_lpm_t net
)
763 const char*ha_init
= 0;
767 switch (ivl_lpm_type(net
)) {
778 /* If this is a single bit wide, then generate only a
779 half-adder. Normally this is an XOR, but if this is a SUB
780 then it is an XNOR. */
781 if (ivl_lpm_width(net
) == 1) {
783 lut
= edif_cellref_create(edf
, xilinx_cell_lut2(xlib
));
785 jnt
= edif_joint_of_nexus(edf
, ivl_lpm_q(net
, 0));
786 edif_add_to_joint(jnt
, lut
, LUT_O
);
788 jnt
= edif_joint_of_nexus(edf
, ivl_lpm_data(net
, 0));
789 edif_add_to_joint(jnt
, lut
, LUT_I0
);
791 jnt
= edif_joint_of_nexus(edf
, ivl_lpm_datab(net
, 0));
792 edif_add_to_joint(jnt
, lut
, LUT_I1
);
794 edif_cellref_pstring(lut
, "INIT", ha_init
);
802 * The left shift is implemented as a matrix of MUX2_1 devices. The
803 * matrix has as many rows as the device width, and a column for each
806 void xilinx_shiftl(ivl_lpm_t net
)
808 unsigned width
= ivl_lpm_width(net
);
809 unsigned nsel
= 0, swid
= 0;
812 edif_cellref_t
* cells
;
813 edif_cellref_t
**table
;
815 edif_cellref_t pad0_cell
;
819 /* First, find out how many select inputs we really need. We
820 can only use the selects that are enough to shift out the
821 entire width of the device. The excess can be used as an
822 enable for the last column. When disabled, the last column
825 while (nsel
< ivl_lpm_selects(net
)) {
836 /* Allocate a matrix of edif_cellref_t variables. A devices
837 will be addressed by the expression table[sdx][qdx];
838 This should make the algorithm code easier to read. */
839 cells
= calloc(nsel
* width
, sizeof(edif_cellref_t
));
840 table
= calloc(nsel
, sizeof(edif_cellref_t
*));
842 for (sdx
= 0 ; sdx
< nsel
; sdx
+= 1)
843 table
[sdx
] = cells
+ sdx
*width
;
845 /* Make a 0 valued pad bit. I will use this for all the shift in
846 values that are beyond the input. */
847 pad0_cell
= edif_cellref_create(edf
, cell_0
);
848 pad0
= edif_joint_create(edf
);
849 edif_add_to_joint(pad0
, pad0_cell
, 0);
851 /* The LUT matrix is <nsel> columns of <width> devices, with
852 the last column a LUT4 devices. The extra input of the
853 LUT4s in the last column are used as an enable to collect
854 all the excess select inputs. */
856 /* Allocate the LUT devices of the matrix, and connect the
857 select inputs to I2 of all the devices of the column. */
858 for (sdx
= 0 ; sdx
< nsel
; sdx
+= 1) {
859 const char*init_string
= 0;
860 ivl_nexus_t nex
= ivl_lpm_select(net
,sdx
);
861 edif_joint_t sdx_jnt
= edif_joint_of_nexus(edf
, nex
);
865 if (((sdx
+1) == nsel
) && (nsel
< ivl_lpm_selects(net
))) {
866 lut
= xilinx_cell_lut4(xlib
);
867 init_string
= "00CA";
869 lut
= xilinx_cell_lut3(xlib
);
873 for (qdx
= 0 ; qdx
< width
; qdx
+= 1) {
874 table
[sdx
][qdx
] = edif_cellref_create(edf
, lut
);
875 edif_add_to_joint(sdx_jnt
, table
[sdx
][qdx
], LUT_I2
);
877 edif_cellref_pstring(table
[sdx
][qdx
], "INIT", init_string
);
881 /* Connect the inputs of the SHIFTL device to the column 0 LUT
882 inputs. The slice on the low end shifts in a 0 for a select
884 for (qdx
= 0 ; qdx
< width
; qdx
+= 1) {
885 ivl_nexus_t nex0
, nex1
;
889 nex0
= ivl_lpm_data(net
,qdx
);
890 jnt0
= edif_joint_of_nexus(edf
, nex0
);
893 nex1
= ivl_lpm_data(net
,qdx
-1);
894 jnt1
= edif_joint_of_nexus(edf
, nex1
);
899 edif_add_to_joint(jnt0
, table
[0][qdx
], LUT_I0
);
900 edif_add_to_joint(jnt1
, table
[0][qdx
], LUT_I1
);
903 /* Make the inner connections between LUT devices. Each column
904 connects to the previous column, shifted by the power of
905 the column value. If the shifted input falls off the end,
906 then pad with zero. */
907 for (sdx
= 1 ; sdx
< nsel
; sdx
+= 1) {
909 for (qdx
= 0 ; qdx
< width
; qdx
+= 1) {
910 unsigned shift
= 1 << sdx
;
911 edif_joint_t jnt0
= edif_joint_create(edf
);
912 edif_joint_t jnt1
= (qdx
>= shift
)
913 ? edif_joint_create(edf
)
916 edif_add_to_joint(jnt0
, table
[sdx
][qdx
], LUT_I0
);
917 edif_add_to_joint(jnt1
, table
[sdx
][qdx
], LUT_I1
);
919 edif_add_to_joint(jnt0
, table
[sdx
-1][qdx
], LUT_O
);
921 edif_add_to_joint(jnt1
, table
[sdx
-1][qdx
-shift
], LUT_O
);
925 /* Connect the output of the last column to the output of the
927 for (qdx
= 0 ; qdx
< width
; qdx
+= 1) {
928 ivl_nexus_t nex
= ivl_lpm_q(net
,qdx
);
929 edif_joint_t jnt
= edif_joint_of_nexus(edf
, nex
);
931 edif_add_to_joint(jnt
, table
[nsel
-1][qdx
], LUT_O
);
934 /* Connect the excess select inputs to the enable inputs of
935 the LUT4 devices in the last column. */
936 if (nsel
< ivl_lpm_selects(net
)) {
939 /* XXXX Only support 1 excess bit for now. */
940 assert((nsel
+ 1) == ivl_lpm_selects(net
));
942 jnt
= edif_joint_of_nexus(edf
, ivl_lpm_select(net
,nsel
));
943 for (qdx
= 0 ; qdx
< width
; qdx
+= 1)
944 edif_add_to_joint(jnt
, table
[nsel
-1][qdx
], LUT_I3
);
954 * Revision 1.13 2007/02/26 19:49:50 steve
955 * Spelling fixes (larry doolittle)
957 * Revision 1.12 2004/02/15 18:03:30 steve
958 * Cleanup of warnings.
960 * Revision 1.11 2004/02/10 16:39:33 steve
961 * Fix direction of Q/D signals of FD devices.
963 * Revision 1.10 2003/08/15 02:23:53 steve
964 * Add synthesis support for synchronous reset.
966 * Revision 1.9 2003/07/04 01:08:03 steve
967 * PAD attribute can be used to assign pins.
969 * Revision 1.8 2003/07/04 00:10:09 steve
970 * Generate MUXF5 based 4-input N-wide muxes.
972 * Revision 1.7 2003/07/03 17:46:33 steve
975 * Revision 1.6 2003/07/02 03:02:15 steve
976 * More xilinx common code.
978 * Revision 1.5 2003/07/02 00:25:40 steve
979 * Add xilinx support for bufif1.
981 * Revision 1.4 2003/06/28 04:18:47 steve
982 * Add support for wide OR/NOR gates.
984 * Revision 1.3 2003/06/26 03:57:05 steve
985 * Add Xilinx support for A/B MUX devices.
987 * Revision 1.2 2003/06/25 02:55:57 steve
988 * Virtex and Virtex2 share much code.
990 * Revision 1.1 2003/04/05 05:53:34 steve
991 * Move library cell management to common file.