[sci.electronics] Xilinx

mckenzie@june.cs.washington.edu (Neil McKenzie) (08/04/89)

Hello netlanders.  I'm using the Xilinx Logic Cell Arrays (LCAs)
and I'm interested in other people's anecdotes, experiences, etc.

The Xilinx chips fit somewhere in between PALs and gate arrays.  They
have a lot of nice features: they are electrically reprogrammable;
every I/O pin can be configured as an input, output or bidirectional pin,
they have a fair number of usable gates, configurable routing, and
their parts are rated as fast as 70 MHz.

The difficulty with Xilinx is that once circuits become complicated, they
become routing-limited, and long routes use CMOS pass-transistors, which
can lead to slow switching.  Designs might only run at 5 to 10 MHz, even
though internally the flip-flops can switch at 70 MHz.

Xilinx also sells a software development system for doing automatic
placement and routing (APR) of the internal logic blocks.  For small designs,
it's adequate, but for larger designs, the result can be a slow running
circuit.  I have heard that many people who want the max speed will
abandon the APR and just do everything by hand, which can be a very tedious
process.

Do you netlanders use competing products (Altera, Actel)?  How do they stack
up, especially in terms of speed?  As far as I know, Xilinx has the only
electrically reprogrammable chips.  This is a *really nice* feature.
I get somewhat paranoid about programming a "burn-once" part that costs
more than a few bucks.

Hope to start some discussion (with light, without too much heat)...

--Neil McKenzie (mckenzie@june.cs.washington.edu)

bill@sigma.UUCP (William Swan) (08/04/89)

In article <8897@june.cs.washington.edu> mckenzie@uw-june.cs.washington.edu (Neil McKenzie) writes:
>Hello netlanders.  I'm using the Xilinx Logic Cell Arrays (LCAs)
>and I'm interested in other people's anecdotes, experiences, etc.

Well, Neil, seeing as you're only a couple miles away (as the bird flies)
maybe we should form a Xilinx user's group! :-)

I have just taken over a design project using same, and have been well
advised as to problems with the XACT design tools, primarily the fact that
it never routes the same way twice! (This has led to our editing of the 
routed device to fix certain small design problems, and updating the
original schematics to -hopefully- match.)


-- 
Bill Swan  entropy.ms.washington.edu!sigma!bill  Send postal address for info:
	Innocent but in prison in Washington State for 13.5 years:
	Ms. Debbie Runyan: incarcerated 01/1989, scheduled release 07/2002.
	                   In now:  0 years,  6 months,  2 weeks,  1 day. 

bradb@tekfdi.FDI.TEK.COM (Brad Barmore) (08/05/89)

In article <8897@june.cs.washington.edu>, mckenzie@june.cs.washington.edu (Neil McKenzie) writes:
> Hello netlanders.  I'm using the Xilinx Logic Cell Arrays (LCAs)
> and I'm interested in other people's anecdotes, experiences, etc.
> 
> Xilinx also sells a software development system for doing automatic
> placement and routing (APR) of the internal logic blocks.  For small designs,
> it's adequate, but for larger designs, the result can be a slow running
> circuit.  I have heard that many people who want the max speed will
> abandon the APR and just do everything by hand, which can be a very tedious
> process.
> 
> Do you netlanders use competing products (Altera, Actel)?  How do they stack
> up, especially in terms of speed?  As far as I know, Xilinx has the only
> electrically reprogrammable chips.  This is a *really nice* feature.
> I get somewhat paranoid about programming a "burn-once" part that costs
> more than a few bucks.
> 
> Hope to start some discussion (with light, without too much heat)...
> 
> --Neil McKenzie (mckenzie@june.cs.washington.edu)

I've used the AMD (or Xilinx) LCAs quite a bit recently.  I chose to use the
AMD (Advanced Micro Devices) support software due to the larger size of 
company and better user support.  Due to a cross license expiration AMD and
Xilinx will begin to go separate directions in support.  My "personal"
feeling is that AMD will provide better support in the long run.

As far as programming for max. speed I've found that APR will do a fairly
good job of placing the blocks if given a very small ending temperature,
but it certainly cannot do a good job of routing nets.  Using a constraint
file will help some, but still expect to spend some time "tweeking" the
layout.  Most of my experience is in the 2000 series parts.  I basically 
enter my state machine design by hand, let APR run in a loop for about 10
runs choose the best design and trash the others, check my critical nets,
and then look for and cleanup bad routes.  This process may take a while
but you will get the maximum results.

Also both AMD and Xilinx have come out with 100MHz versions of their parts.

I have no affilation with AMD or Xilinx.  This information is derived from
my own use of their components and support.

Just another happy, but tired EE.
Brad Barmore
Tektronix, Inc.

Thomas@cup.portal.com (Tom Newton Biggs) (08/05/89)

I have used Xilinx parts in a couple of designs. I have used their biggest
parts, the 3090, which is supposed to be equivalent to 6000 or so gates.
The problem with this part is that to design with it you need at least
6 Meg of memory in your pc, and the pc must be a fast '386 type or it
is frustatingly slow. We also have the Mentor graphics interface, which
runs on Apollo workstations and allows Mentor CAD to be used to draw
schematics, which are then converted into a netlist, which can be made
into a prom to program the 3090. There are several problems with the
Apollo software though. First, it has LOTS of bugs. I don't think that
Xilinx programmers really understand Mentor that well. Second, it isn't
complete. The netlist still has to be downloaded into a PC to do anly
hand layout and to convert to a prom.
Another note: AMD is a second source for several of the Xilinx parts.

henry@utzoo.uucp (Henry Spencer) (08/06/89)

In article <21040@cup.portal.com> Thomas@cup.portal.com (Tom Newton Biggs) writes:
>The problem with this part is that to design with it you need at least
>6 Meg of memory in your pc, and the pc must be a fast '386 type or it
>is frustatingly slow...

Well, the *problem* with this part, and with a number of other programmable-
logic devices for that matter, is that the algorithm for converting circuit
to programming bits is secret.  The software would improve if it had some
competition.
-- 
1961-1969: 8 years of Apollo.  |     Henry Spencer at U of Toronto Zoology
1969-1989: 20 years of nothing.| uunet!attcan!utzoo!henry henry@zoo.toronto.edu

rpw3@amdcad.AMD.COM (Rob Warnock) (08/08/89)

In article <1989Aug5.224902.4724@utzoo.uucp> Henry Spencer writes:
+---------------
| >The problem with this part is that to design with it you need at least
| >6 Meg of memory in your pc, and the pc must be a fast '386 type or it
| >is frustatingly slow...
| Well, the *problem* with this part, and with a number of other programmable-
| logic devices for that matter, is that the algorithm for converting circuit
| to programming bits is secret.  The software would improve if it had some
| competition.
+---------------

And that's not likely to happen soon, since Xylinks is probably making almost
as much off the software as they are off the parts!  (...at least until all
the users who are prototyping them in now in onesy-twosies now go into full
production with their products.)

Of course, if you have access to a copy of the software, and *LOTS* of
time, I guess you could always try to reverse-engineer the pattern, by
taking the "diff" of the bitstreams for pairs of designs which differ by
one "bit" (or gate, whatever). But don't hold your breath... ;-}  ;-}


Rob Warnock
Systems Architecture Consultant

UUCP:	  {amdcad,fortune,sun}!redwood!rpw3
DDD:	  (415)572-2607
USPS:	  627 26th Ave, San Mateo, CA  94403

neals@tekigm2.MEN.TEK.COM (Neal Sedell) (08/08/89)

Speaking (not very kindly) of programmable logic development tools, has anyone
ever tried using low true outputs with a programmable output polarity device
like a 22V10 using (un)Abel??? (I'd give the trademark disclaimer but I don't
want to embarass Data I/O.  Oops! ;-)).  I have wasted soooooo much time trying
to describe a couple of these I've done in a reasonable fashion, but the tool
is so DAMN brain-damaged that there's just no way to do it.  The manuals are
virtually useless, except for the examples, which with lots of your time you
may find enough hints in several of which to get you where you need to go.
Registered low outputs on same 22V10's are even more of a pain, at least if
you use the State_Diagram syntax.  I ended up declaring the pins as _XXX,
redefining them as XXX = !_XXX for readability, and having to declare them
as "reg, neg" in an IsType statement just to get the darn thing not to generate
NULL equations for the non-state-variable terms.  Seems to want to AND
said terms with 1 XOR !(0) (something like that) turning all the terms to 0.
If I wanted a constant level I would've just tied the inputs high or low.

   This is all on the PC version 3.10 just released, but it works the same
way on a uVAX running 3.00.  I shudder contemplating the next and last PLD
I have to do for a project, because last time both Abel and Palasm insisted
in de-minimizing my DMA state machine so badly it wouldn't fit in the target
device!  I used to use Palasm all the time but moved up to Abel since it did
address decoding so nicely.  I guess that's all it does nicely ;-).  At least
in Palasm when you defined a pin a low-true it actually took your word for it!

Flame out,

-- 
# Neal Sedell     (206) 253-5280
# aka   neals@tekigm2.MEN.TEK.COM
# Tektronix, Inc., Delivery C1-936
# PO Box 3500, Vancouver, WA  98668

jones@optilink.UUCP (Marvin Jones) (08/09/89)

We are using a LOT of Xilinx parts in our new product.  Among other things, 
there are major problems with several of the mask sets regarding reset 
operation.  We have had to add 10 gates or so around ALL versions of the parts 
in order to adequately control the reset timing going to both the Xilinx 
arrays as well as the 1736 serial configuration PROMs.  

We have also seen process variations between various runs of the arrays which
can cause lockups during the power up initialization phase when using a 
master / slave serial configuration loading scheme.  This requires an 
additional gate between the Init lead of the slave and the Reset lead of the 
master.  

Yes, they are clever parts.  Very versatile and fast for prototype 
development.  But lately we are working harder on generating "real" custom 
VLSI to avoid an ever growing number of Xilinx "surprises" we are finding. 
I have not been that deeply involved with the problem resolution, but can 
provide more information if desired.  

 

jsnow@esunix.UUCP (John Snow) (08/09/89)

From article <1989Aug5.224902.4724@utzoo.uucp>, by henry@utzoo.uucp (Henry Spencer):
> 
> Well, the *problem* with this part, and with a number of other programmable-
> logic devices for that matter, is that the algorithm for converting circuit
> to programming bits is secret.  The software would improve if it had some
> competition.
> -- 
> 1961-1969: 8 years of Apollo.  |     Henry Spencer at U of Toronto Zoology
> 1969-1989: 20 years of nothing.| uunet!attcan!utzoo!henry henry@zoo.toronto.edu

AMD is just releasing their version of the LCA software.  AMD is a second
source for Xilinx parts and the AMD sales rep told me that their new software
is NEW and is not a copy of the Xilinx software.

-- 
-----------------------------------------------------------------------------
John F. Snow                         UUCP: {ihnp4,decvax}!decwrl!esunix!jsnow 
Evans & Sutherland Computer Corp.      or:         uunet!utah-cs!esunix!jsnow
Salt Lake City, Utah                 AppleLink PE: JohnSnow    GEnie: J.SNOW2

patp@pedsga.UUCP (Pat Payton) (08/15/89)

We are currently involved in a design that will be using many Xilinx parts.
We would greatly appreciate any DETAILED information concerning bugs, problems,
suggestions, etc. that you can provide. Thanks.