1 |
216 |
guanucolui |
%*****************************************************************************************
|
2 |
125 |
guanucolui |
%*********************************** Second Chapter **************************************
|
3 |
|
|
%*****************************************************************************************
|
4 |
|
|
|
5 |
208 |
guanucolui |
\chapter{Fundamentos Básicos}
|
6 |
|
|
\label{chap:fundamentos}
|
7 |
125 |
guanucolui |
|
8 |
|
|
\ifpdf
|
9 |
|
|
\graphicspath{{Chapter2/Figs/Raster/}{Chapter2/Figs/PDF/}{Chapter2/Figs/}}
|
10 |
|
|
\else
|
11 |
|
|
\graphicspath{{Chapter2/Figs/Vector/}{Chapter2/Figs/}}
|
12 |
|
|
\fi
|
13 |
|
|
|
14 |
208 |
guanucolui |
%La \emph{electrónica} ha revolucionado del siglo XX y sigue siendo un impacto en el siglo XXI. El nacimiento y subsecuente crecimiento de la industria de la computación, la creación del teléfono móvil y la \emph{digitalización} de los servicios de televisión y radio son ejemplos de grandes logros tecnológicos que la electrónica ha ofrecido. En las décadas de 1970 y 1980, los sistemas electrónicos se encontraban compuestos de componentes estándares como microprocesadores y varios circuitos integrados (\textsl{Integrated Circuits}, ICs), todo esto sobre una placa de circuitos impresos (\textsl{Print Circuit Boards}, PCBs. Como el nivel de integración creció, el proceso de fabricación de los PCBs se convirtió cada vez más complejo. Esto se debió al incremento de transistores y pines de entrada/salida que implicó el uso de placas multi-capas, logrando desarrollar placas con hasta 20 capas. Así, la probabilidad de conexiones de componentes en forma incorrecta aumentó, particularmente la posibilidad de diseñar con éxitos y probar un sistema en forma funcional antes de ingresar a un proceso de producción.
|
15 |
|
|
|
16 |
127 |
guanucolui |
\section{Dispositivos Lógicos Programables}
|
17 |
208 |
guanucolui |
\label{sec:fund-pld}
|
18 |
125 |
guanucolui |
|
19 |
208 |
guanucolui |
Los \emph{Dispositivos Lógicos Programables} (PLDs) fueron introducidos a medidos de 1970s. La idea era construir circuitos lógicos combinacionales que fueran \emph{programables}. Contrariamente a los microprocesadores, los cuales pueden \emph{correr} un programa sobre un hardware \emph{fijo}, la programabilidad de los PLDs hace referencia a niveles de \emph{hardware}. En otras palabras, un PLD es un chip de \emph{propósitos generales} cuyo \emph{hardware} puede ser reconfigurado dependiendo de especificaciones particulares del programador.
|
20 |
125 |
guanucolui |
|
21 |
128 |
guanucolui |
EL primer PLD se llamaba PAL (\textsl{Programmable Array Logic}). Estos dispositivos disponían solo de compuertas lógicas (no tenían flip-flop), por lo que solo permitía la implementación de circuitos \emph{combinacionales}. Para salvar este problema, Los \emph{\textsl{registered}} PLDs fueron lanzados pocos después, los cuales incluían un flip-flop por cada salida del circuito. Con esta versión de los PAL, se podría implementar funciones \emph{secuenciales} simples.
|
22 |
125 |
guanucolui |
|
23 |
128 |
guanucolui |
En el comienzo de 1980s, se agregaba más circuitos lógicos adicionales a la salida de los PLD. Este circuito de salida se lo identificaba como celda, llamado también \emph{Microcelda}, que contenía (además de flip-flop) compuertas lógicas y multiplexores. Por otra parte, la celda era reprogramable, permitiendo varios modos de operación. Además, se podía proveer una señal de retorno (\textsl{feedback}) desde la salida del circuito a la lógico principal de la PAL, lo que le daba mayor flexibilidad a estos dispositivos reprogramables. Esta nueva estructura era llamada \emph{\textsl{generic PAL}} o GAL. Una arquitectura de dispositivo similar fue conocido como PALCE (\textsl{PAL CMOS Electrically erasable/programmable}).
|
24 |
|
|
|
25 |
|
|
Todos estos chips (PAL, \textsl{registered} PLD, y GAL/PALCE) son ahora categorizados como SPLDs (\textsl{Simple} PLDs). Los dispositivos GAL/PALCE son los únicos fabricados aún en una encapsulado independiente.
|
26 |
|
|
|
27 |
|
|
Luego, varios dispositivos GAL fueron fabricados en un solo chip, usando un esquema de direccionamiento más sofisticado, mayor tecnología en su fabricación, y varias características adicionales (como soporte JTAG e interfaces para varios estándares lógicos). Esta nueva propuesta se la conoció como CPLD (\textsl{Complex} PLD). Los CPLDs son actualmente muy populares debido a su alta densidad, funcionalidad, y bajo costo.
|
28 |
|
|
|
29 |
|
|
Finalmente, a mediados de 1980s, las FPGA (\textsl{Field Programmable Gate Array}) fueron introducidos al mercado de los IC. Las FPGAs diferían de los CPLDs en su arquitectura. tecnología, recursos internos, y costo. Estos dispositivos tenían como principal objetivo su implementación en diseños de gran requerimientos en recursos de hardware como así también un alto rendimiento.
|
30 |
|
|
|
31 |
|
|
Un pequeño resumen de los diferentes dispositivos PLDs se puede observar en la Tabla \ref{tab:evo-plds}.
|
32 |
|
|
|
33 |
|
|
\begin{table}[h]
|
34 |
127 |
guanucolui |
\centering
|
35 |
208 |
guanucolui |
\begin{tabular}[h]{|c|ll|}
|
36 |
128 |
guanucolui |
\hline
|
37 |
|
|
\multirow{5}{*}{PLDs} & \multirow{3}{*}{Sample PLD (SPLD)} & \multicolumn{1}{|l|}{PAL} \\
|
38 |
208 |
guanucolui |
& & \multicolumn{1}{|l|}{Registered PAL} \\
|
39 |
|
|
& & \multicolumn{1}{|l|}{GAL} \\ \cline{2-3}
|
40 |
|
|
& Complex PLD (CPLD) & \\ \cline{2-3}
|
41 |
|
|
& FPGA & \\
|
42 |
128 |
guanucolui |
\hline
|
43 |
|
|
\end{tabular}
|
44 |
208 |
guanucolui |
\caption{Evolución de los PLDs.}
|
45 |
128 |
guanucolui |
\label{tab:evo-plds}
|
46 |
|
|
\end{table}
|
47 |
125 |
guanucolui |
|
48 |
128 |
guanucolui |
Por último, todos los PLDs (\textsl{simple} o \textsl{complex}) son no volátiles. Estos puede ser OTP (\textsl{One-Time Programmable}), en la que pequeños fusibles electrónicos son usados para la reprogramación, de igual forma que las EEPROM o memorias Flash. Las FPGAs, por otra lado, son en su mayoría volátiles. Para estas últimas se deben usar dispositivos externos para cargar las conexiones.
|
49 |
125 |
guanucolui |
|
50 |
208 |
guanucolui |
%Actualmente los dispositivos más utilizados son los CPLDs y FPGAs. De estas dos tecnología, se optó por trabajar con las FPGAs pues, como bien se dijo antes, cuentan con mayor recursos de \textsl{hardware} que los CPLDs. Lo que permitirá dar un mayor margen a los desarrollos digitales que se quieran implementar. Se detallará con mayor profundidad la tecnología y estructura de las FPGAs.
|
51 |
125 |
guanucolui |
|
52 |
208 |
guanucolui |
\section{SPLDs}
|
53 |
|
|
\label{sec:fund-pld-spld}
|
54 |
127 |
guanucolui |
|
55 |
208 |
guanucolui |
Como se mencionó anteriormente, los dispositivos PAL, PLA y GAL se clasifican como los \textsl{Simple} PLD (SPLDs). Una descripción de las arquitecturas de cada uno de estos dispositivos se presenta a continuación.
|
56 |
|
|
|
57 |
|
|
\subsection{PALs}
|
58 |
|
|
\label{sec:fund-pld-spld-pal}
|
59 |
|
|
|
60 |
|
|
Los \textsl{Programmable Array Logic} (PAL) son introducidos por Monolithic Memories Inc. a mediados de 1970. Su arquitectura básica se ilustra en la Figura \ref{fig:pal-arch}, donde se representa con un pequeño círculo las conexiones programables. Como puede verse, el circuito esta compuesto de un arreglo de compuertas AND \emph{programables}, seguido por un arreglo \emph{fijo} de compuertas OR.
|
61 |
|
|
|
62 |
|
|
La implementación de la Figura \ref{fig:pal-arch} se basa en que cualquier función combinacional puede ser representada como una Suma de Productos (SOP); es decir, si $a_1$, $a_2$, $\cdots$, $a_N$ son las entradas lógicas, entonces cualquier salida combinacional $x$ puede ser compuesta como
|
63 |
|
|
\begin{equation}
|
64 |
|
|
\label{eq:sop}
|
65 |
|
|
x = m_1 + m_2 + \cdots + m_M \text{ ,}
|
66 |
|
|
\end{equation}
|
67 |
|
|
donde $m_i = f_1\left(a_1,a_2,\cdots,a_N\right)$ son los términos mínimos de la función $x$. Por ejemplo
|
68 |
|
|
\begin{equation}
|
69 |
|
|
\label{eq:sop-2}
|
70 |
|
|
x = a_1\bar{a}_2 + a_2a_3\bar{a}_4 + \bar{a}_1\bar{a}_2a_3a_4\bar{a}_5
|
71 |
|
|
\end{equation}
|
72 |
|
|
|
73 |
|
|
Por lo tanto, el producto (términos mínimos) puede ser obtenido por medio de las compuertas AND, cuya salidas están conectadas a una compuerta OR para calcular su suma.
|
74 |
|
|
|
75 |
|
|
\begin{figure}
|
76 |
|
|
\centering
|
77 |
|
|
\includegraphics[width=0.5\textwidth]{PAL}
|
78 |
|
|
\caption{Arquitectura básica de una PAL.}
|
79 |
|
|
\label{fig:pal-arch}
|
80 |
|
|
\end{figure}
|
81 |
|
|
|
82 |
|
|
La principal limitación de esta arquitectura es el hecho de que solo permite la implementación de funciones combinacionales solamente. Para solucionar este problema, las \textsl{registered} PALs fueron lanzadas a fines de la década de 1970s. Estas incluían un flip-flop en cada salida (luego de la compuerta OR en la Figura \ref{fig:pal-arch}), de esta manera permitió la implementación de funciones secuenciales (aunque muy simples).
|
83 |
|
|
|
84 |
|
|
La primeras tecnologías empleadas en la fabricación de los dispositivos PALs fue bipolar, con una tensión de alimentación de 5V y un consumo de corriente al rededor de 200mA. La máxima frecuencia rondaba los 100Mhz, y las celdas programables eran de PROM (\textsl{fuse links}) o EPROM (con un tiemp de borrado de 20min. UV).
|
85 |
|
|
|
86 |
|
|
\subsection{PLAs}
|
87 |
|
|
\label{sec:fund-pld-spld-pla}
|
88 |
|
|
|
89 |
|
|
Los PLA (\textsl{Programmable Logic Array}) fueron introducidos a mediados de 1970s (por Signetics Inc.). La arquitectura básica de un PLA se ilustra simbólicamente en la Figura \ref{fig:pla-arch}. Si comparamos esta arquitectura con la Figura \ref{fig:pal-arch}, se observa que la única diferencia fundamental entre estos es que mientras una PAL tiene compuertas AND programables y otras compuertas OR fijas, en el caso de las PLA \emph{ambas} (las compuertas AND y OR) son programables. De esta manera se logra una ventaja en la flexibilidad del diseño. Sin embargo, se presentan elevados tiempos de retardos en los nodos de conexión internos que reducen la velocidad de funcionamiento del circuito.
|
90 |
|
|
|
91 |
|
|
\begin{figure}
|
92 |
|
|
\centering
|
93 |
216 |
guanucolui |
\includegraphics[width=0.5\textwidth]{PLA}
|
94 |
208 |
guanucolui |
\caption{Arquitectura básica de una PLA.}
|
95 |
|
|
\label{fig:pla-arch}
|
96 |
|
|
\end{figure}
|
97 |
|
|
|
98 |
|
|
La tecnología que se empleó en la fabricación de las PLAs fue la misma que en el caso de las PALs. Aunque las PLAs se encuentran obsoletas actualmente, estos han reaparecido como parte de las arquitecturas de las primeras familias de los CPLDs de baja potencia, como por ejemplo la familia de los \emph{CoolRunner} (de Xilinx Inc.).
|
99 |
|
|
|
100 |
|
|
\subsection{GALs}
|
101 |
|
|
\label{sec:fund-pld-spld-gal}
|
102 |
|
|
|
103 |
|
|
La arquitectura de las GAL (\textsl{Generic} PAL) fueron introducidas por Lattice Inc. en los comienzos de 1980s. Este contenía varias mejoras sobre los primeros dispositivos PALs:
|
104 |
|
|
\begin{enumerate}
|
105 |
|
|
\item Se construyeron sealidas más sofisticadas de las celdas (\emph{Macrocell}), las que incluían, además de flip-flop, varias compuertas y multiplexores.
|
106 |
|
|
\item Las Macrocell eran programables, permitiendo varios modos de operación.
|
107 |
|
|
\item Una señal de ``retorno'' desde la salida a la Marocell al arreglo reprogramable se incluyó, confiriendo al circuito mayor versatilidad.
|
108 |
|
|
\item Se utilizaron EEPROM en lugar de la PROM o EPROM.
|
109 |
|
|
\end{enumerate}
|
110 |
|
|
Como se mencionó, la GAL es el único SPLD que todavía es fabricado en un encapsulado estándar. Además, éste también sirvió como parte en la construcción de la mayoría de los CPLDs.
|
111 |
|
|
|
112 |
|
|
La Figura \ref{fig:gal-arch} muestra un ejemplo de un dispositivo GAL, el GAL16V8. Este circuito cuenta con 16 entradas y 8 salidas, en un \textsl{package} de 20 pines. En cada salida hay una Macrocell (luego de la compuerta OR), que contiene, además del flip-flop, compuertas lógicas y multiplexores. Las interconexiones programables son representadas por pequeños círculos. Una señal de realimentación desde la Macrocell al arreglo programable puede también ser observado. Notar que esta arquitectura se asemeja directamente a la de la PAL (Figura \ref{fig:pal-arch}), excepto por la presencia de una macrocell en cada salida y la señal de realimentación.
|
113 |
|
|
|
114 |
|
|
\begin{figure}
|
115 |
|
|
\centering
|
116 |
|
|
\includegraphics[width=0.9\textwidth]{GAL}
|
117 |
|
|
\caption{Dispositivo GAL 16V8.}
|
118 |
|
|
\label{fig:gal-arch}
|
119 |
|
|
\end{figure}
|
120 |
|
|
|
121 |
|
|
Actualmente los dispositivos GALs usan tecnología CMOS, alimentados a 3.3V, tecnología EEPROM o Flash, y alcanzan frecuencias máximas que rondan los 250Mhz. Varias compañías fabrican estos dispositivos (Lattice, Atmel, Texas Instruments, etc.).
|
122 |
|
|
|
123 |
|
|
\section{CPLDs}
|
124 |
|
|
\label{sec:fund-pld-cpld}
|
125 |
|
|
|
126 |
|
|
La estructura fundamental en la arquitectura de los CPLDs se ilustra en la Figura \ref{fig:cpld-arch}. Como se puede ver, este consiste en varios PLDs (en general del tipo GAL) con una matriz de \textsl{switches} programables usadas para conectarlos todos juntos a al bloque de entrada y salida. Además, los CPLDs contiene normalmente otras características, como soporte JTAG e interfaz a otros estándares lógicos (1.8V, 2.5V, 5V, etc.).
|
127 |
|
|
|
128 |
|
|
\begin{figure}
|
129 |
|
|
\centering
|
130 |
|
|
\includegraphics[width=0.4\textwidth]{CPLD}
|
131 |
|
|
\caption{Arquitectura básica de un CPLD.}
|
132 |
|
|
\label{fig:cpld-arch}
|
133 |
|
|
\end{figure}
|
134 |
|
|
|
135 |
|
|
Son varias las compañías que fabrican CPLDs, entre las más reconocidas tenemos Xilinx, Altera, Lattice, Atmel, Cypress, etc. En las Tablas \ref{tab:char-cpld-xilinx} y \ref{tab:char-cpld-altera} se disponen de las características de dos CPLDs, Xilinx y Altera. Como puede verse, más ade 500 Macrocells y más de 10000 compuertas pueden encontrarse en estos dispositivos.
|
136 |
|
|
|
137 |
|
|
\begin{table}%[h]
|
138 |
|
|
\centering
|
139 |
|
|
{\footnotesize
|
140 |
|
|
\begin{tabular}[c]{|m{0.2\textwidth}|m{0.2\textwidth}|m{0.2\textwidth}|m{0.2\textwidth}|}%{|l|l|l|l|}
|
141 |
|
|
\hline
|
142 |
|
|
Familia & \textbf{XC9500 (XVm, XL)} & \textbf{CoolRunner XPLA3} & \textbf{CoolRunner II} \\
|
143 |
|
|
\hline
|
144 |
|
|
Macrocell & 36 -- 288 & 32 -- 512 & 32 -- 512 \\
|
145 |
|
|
\hline
|
146 |
|
|
\textsl{System gates} & 800 -- 6,400 & 750 -- 12,000 & 750 -- 12,000 \\
|
147 |
|
|
\hline
|
148 |
|
|
Pines I/O & 34 --192 & 36 -- 260 & 33 -- 270 \\
|
149 |
|
|
\hline
|
150 |
|
|
Frec. máxima interna & 222 Mhz & 213 Mhz & 350 Mhz \\
|
151 |
|
|
\hline
|
152 |
|
|
\multirow{2}{*}{\textsl{Building Block}} & GAL 54V18 (XV, XL) & Bloques PLA & Bloques PLA \\
|
153 |
|
|
& GAL 36V18 (--) & & \\
|
154 |
|
|
\hline
|
155 |
|
|
Voltaje & 2.5 V (XV), 3.3 V (XL), 5 V & 3.3 V & 1.8 V \\
|
156 |
|
|
\hline
|
157 |
|
|
Interconexiones & Flash & EEPROM & \\
|
158 |
|
|
\hline
|
159 |
|
|
Tecnología & 0.35 $\mu$ CMOS & 0.35 $\mu$ CMOS & 0.18 $\mu$ CMOS \\
|
160 |
|
|
\hline
|
161 |
|
|
Corriente estática & 11 -- 500 mA & < 0.1 mA & 22 $\mu$A -- 1 mA \\
|
162 |
|
|
\hline
|
163 |
|
|
\end{tabular}
|
164 |
|
|
} % END \footnotesize{} segmentation
|
165 |
|
|
\caption{Características de los CPLDs de Xilinx.}
|
166 |
|
|
\label{tab:char-cpld-xilinx}
|
167 |
|
|
\end{table}
|
168 |
|
|
|
169 |
|
|
\begin{table}%[h]
|
170 |
|
|
\centering
|
171 |
|
|
{\footnotesize
|
172 |
|
|
\begin{tabular}[c]{|m{0.2\textwidth}|m{0.2\textwidth}|m{0.2\textwidth}|m{0.2\textwidth}|}%{|l|l|l|l|}
|
173 |
|
|
\hline
|
174 |
|
|
Familia & \textbf{MAX7000 (B, AE, S)} & \textbf{MAX3000 (A)} & \textbf{MAX II (G)} \\
|
175 |
|
|
\hline
|
176 |
|
|
\multirow{2}{*}{Macrocell /} & 32 -- 512 macrocells & 32 -- 512 macrocells & 192 -- 1,700 macrocells \\
|
177 |
|
|
LUTs & & & 240 -- 2,210 LUTs \\
|
178 |
|
|
\hline
|
179 |
|
|
\textsl{System gates} & 600 -- 10,000 & 600 -- 10,000 & \\
|
180 |
|
|
\hline
|
181 |
|
|
Pines I/O & 32 --512 & 34 -- 208 & 80 -- 272 \\
|
182 |
|
|
\hline
|
183 |
|
|
Frec. máxima interna & 303 Mhz & 227 Mhz & 304 Mhz \\
|
184 |
|
|
\hline
|
185 |
|
|
Voltaje & 2.5 V (B), 3.3 V (AE), 5 V (S) & 3.3 V & 1.8 V (G), 2.5 V, 3.3 V \\
|
186 |
|
|
\hline
|
187 |
|
|
Interconexiones & EEPROM & EEPROM & Flash + SRAM \\
|
188 |
|
|
\hline
|
189 |
|
|
\multirow{2}{*}{Tecnología} & 0.22 $\mu$ CMOS EEPROM & 0.3 $\mu$ & 0.18 $\mu$ \\
|
190 |
|
|
& 4 capas de metal (7000 B) & 4 capas de metal & 6 capas de metal \\
|
191 |
|
|
\hline
|
192 |
|
|
Corriente estática & 9 -- 450 mA & 9 -- 150 mA & 2 --50 mA \\
|
193 |
|
|
\hline
|
194 |
|
|
\end{tabular}
|
195 |
|
|
} % END \footnotesize{} segmentation
|
196 |
|
|
\caption{Características de los CPLDs de Altera.}
|
197 |
|
|
\label{tab:char-cpld-altera}
|
198 |
|
|
\end{table}
|
199 |
|
|
|
200 |
|
|
\section{FPGAs}
|
201 |
|
|
\label{sec:fund-pld-fpga}
|
202 |
|
|
|
203 |
128 |
guanucolui |
Las FPGAs fueron introducidas al mercado por la empresa Xilinx Inc. a mediados de 1980s. Estos dispositivos se diferencian de los CPLDs en su arquitectura, tecnología de almacenamiento, funcionalidades integradas, y costo, y además están orientadas a la implementación de altos rendimientos y grandes tamaños en lo que se refiere a recursos de hardware.
|
204 |
127 |
guanucolui |
|
205 |
128 |
guanucolui |
La arquitectura básica de una FPGA se ilustra en la Figura \ref{fig:fpga-arch}. Esta consiste de una matriz de \emph{CLBs} (\textsl{Configurable Logic Blocks}), interconectados por un arreglo de matrices de conmutadores (\emph{\textsl{Switch Matrix}}). Para caracterizar con más detalle estos dispositivo se debe recurrir a la información de los fabricantes, donde además se puede disponer de un interfaz JTAG a diversos niveles lógicos, otra funcionalidad como memorias SRAM, multiplicadores de clock (PLL o DLL), interfaz PCI, etc. Algunos chips también incluyen bloques dedicados como multiplicadores, DPSs, y microprocesadores.
|
206 |
127 |
guanucolui |
|
207 |
128 |
guanucolui |
\begin{figure}
|
208 |
|
|
\centering
|
209 |
|
|
\includegraphics[width=0.4\textwidth]{fpga_arch}
|
210 |
208 |
guanucolui |
\caption{Arquitectura básica de una FPGA.}
|
211 |
128 |
guanucolui |
\label{fig:fpga-arch}
|
212 |
|
|
\end{figure}
|
213 |
127 |
guanucolui |
|
214 |
128 |
guanucolui |
Las FPGAs puede ser muy sofisticadas. La fabricación de chips con una tecnología CMOS de 90 nm., con nueve capas ed cobre y mas de 1000 pines de I/O, se encuentran actualmente disponible en el mercado. Algunos ejemplos de los empaquetados (\textsl{package}) de las FPGAs son ilustrados en la Figura \ref{fig:pkg-fpga}, en los cuales se puede apreciar uno de los \textsl{package} más pequeños (Fig. \ref{fig:pgk-fpga-vq100}) con 100 pines, un \textsl{package} de tamaño mediano (Fig. \ref{fig:pgk-fpga-csg324}) de 324 pines, y uno de los grandes \textsl{package} con 1156 pines (Fig. \ref{fig:pgk-fpga-ffg1156}.
|
215 |
127 |
guanucolui |
|
216 |
128 |
guanucolui |
\begin{figure}
|
217 |
|
|
\centering
|
218 |
|
|
\subfloat[\footnotesize{\textsl{Package} VQ100}]{\label{fig:pgk-fpga-vq100}\includegraphics[width=0.25\textwidth]{pkg100}}
|
219 |
|
|
\qquad
|
220 |
|
|
\subfloat[\footnotesize{\textsl{Package} CSG324}]{\label{fig:pgk-fpga-csg324}\includegraphics[width=0.25\textwidth]{pkg356}}
|
221 |
|
|
\qquad
|
222 |
|
|
\subfloat[\footnotesize{\textsl{Package} FFG1156}]{\label{fig:pgk-fpga-ffg1156}\includegraphics[width=0.25\textwidth]{pkg1156}}
|
223 |
|
|
\caption{Diferentes \textsl{package} de las FPGAs comerciales.}
|
224 |
|
|
\label{fig:pkg-fpga}
|
225 |
125 |
guanucolui |
\end{figure}
|
226 |
|
|
|
227 |
208 |
guanucolui |
Varias compañías fabrican FPGAs, como Xilinx., Actel, Altera, QuickLogic, Atmel, etc. Ejemplo de dos fabricantes (Xilinx y Actel) se disponen en las Tablas \ref{tab:char-fpga-xilinx} y \ref{tab:char-fpga-actel}. Como puede verse, estos dispositivos pueden contener miles de flip-flops y varios millones de compuertas lógicas.
|
228 |
125 |
guanucolui |
|
229 |
208 |
guanucolui |
\begin{table}%[h]
|
230 |
128 |
guanucolui |
\centering
|
231 |
|
|
{\footnotesize
|
232 |
|
|
\begin{tabular}[c]{|m{0.1\textwidth}|m{0.1\textwidth}|m{0.1\textwidth}|m{0.1\textwidth}|m{0.1\textwidth}|m{0.1\textwidth}|m{0.1\textwidth}|m{0.1\textwidth}|}
|
233 |
|
|
\hline
|
234 |
208 |
guanucolui |
Familia & \textbf{Virtex II Pro} & \textbf{Virtex II} & \textbf{Virtex E} & \textbf{Virtex} & \textbf{Spartan 3} & \textbf{Spartan IIE} & \textbf{Spartan II} \\
|
235 |
128 |
guanucolui |
\hline
|
236 |
|
|
CLBs & 352 -- 11.024 & 64 -- 11.648 & 384 -- 16.224 & 384 -- 6.144 & 192 -- 8.320 & 384 -- 3.456 & 96 -- 1.176 \\
|
237 |
|
|
\hline
|
238 |
|
|
Celdas Lógicas & 3.168 -- 125.136 & 576 -- 104.882 & 1.728 -- 73.008 & 1.728 -- 27.648 & 1.728 -- 74.880 & 1.728 -- 15.552 & 432 -- 5.292 \\
|
239 |
|
|
\hline
|
240 |
|
|
\textsl{System gates} & & 40k -- 8M & 72k -- 4M & 58k -- 1.1M & 50k -- 5M & 23k -- 600k & 15k -- 200k \\
|
241 |
|
|
\hline
|
242 |
|
|
Pines de I/O & 204 -- 1200 & 88 -- 1108 & 176 -- 804 & 180 -- 512 & 124 -- 784 & 182 -- 514 & 86 -- 284 \\
|
243 |
|
|
\hline
|
244 |
|
|
Flip-flops & 2.816 -- 88.192 & 512 -- 93.184 & 1.392 -- 64.896 & 1.392 -- 24.576 & 1.536 -- 66.560 & 1.536 -- 13.824 & 384 -- 4.704 \\
|
245 |
|
|
\hline
|
246 |
|
|
Frec. máxima interna & 547 MHz & 420 MHz & 240 MHz & 200 MHz & 326 MHz & 200 MHz & 200 MHz \\
|
247 |
|
|
\hline
|
248 |
|
|
Voltaje & 1.5 V & 1.5 V & 1.8 V & 2.5 V & 1.2 V & 1.8 V & 2.5 V \\
|
249 |
|
|
\hline
|
250 |
|
|
Inter\-conexiones & SRAM & SRAM & SRAM & SRAM & SRAM & SRAM & SRAM \\
|
251 |
|
|
\hline
|
252 |
|
|
\multirow{3}{*}{Tecnología} & 0.13 $\mu$m & .15 $\mu$m & 0.18 $\mu$m & 0.22 $\mu$m & 0.09 $\mu$m & & \\
|
253 |
|
|
& 9 capas de cobre & 8 capas de metal & 6 capas de metal & 5 capas de metal & 8 capas de metal & & \\
|
254 |
|
|
& CMOS & CMOS & CMOS & CMOS &CMOS & & \\
|
255 |
|
|
\hline
|
256 |
|
|
SRAM bits (Bloques de RAM) & 216k -- 8M & 72k -- 3M & 64k -- 832k & 32k -- 128k & 72k -- 1.8M & 32k -- 288k & 16k -- 56k \\
|
257 |
|
|
\hline
|
258 |
|
|
\end{tabular}
|
259 |
|
|
} % END \footnotesize{} segmentation
|
260 |
|
|
\caption{Características de FPGAs fabricadas por Xilinx.}
|
261 |
208 |
guanucolui |
\label{tab:char-fpga-xilinx}
|
262 |
128 |
guanucolui |
\end{table}
|
263 |
125 |
guanucolui |
|
264 |
208 |
guanucolui |
\begin{table}%[h]
|
265 |
128 |
guanucolui |
\centering
|
266 |
|
|
{\footnotesize
|
267 |
|
|
\begin{tabular}[c]{|m{0.13\textwidth}|m{0.13\textwidth}|m{0.13\textwidth}|m{0.13\textwidth}|m{0.13\textwidth}|m{0.13\textwidth}|}
|
268 |
|
|
\hline
|
269 |
208 |
guanucolui |
Familia & \textbf{Accelerator} & \textbf{ProASIC} & \textbf{MX} & \textbf{SX} & \textbf{eX} \\
|
270 |
128 |
guanucolui |
\hline
|
271 |
|
|
Módulos lógicos & 2.016 -- 32.256 & 5.376 -- 56.320 & 295 -- 2.438 & 768 -- 6.036 & 192 -- 768 \\
|
272 |
|
|
\hline
|
273 |
|
|
\textsl{System gates} & 125k -- 2M & 75k -- 1M & 3k -- 54k & 12k -- 108k & 3k -- 12k \\
|
274 |
|
|
\hline
|
275 |
|
|
Pines de I/O & 168 -- 684 & 204 -- 712 & 57 -- 202 & 130 -- 360 & 84 -- 132 \\
|
276 |
|
|
\hline
|
277 |
|
|
Flip-flops & 1.344 -- 21.504 & 5.376 -- 26.880 & 147 -- 1.822 & 512 -- 4.024 & 128 -- 512 \\
|
278 |
|
|
\hline
|
279 |
|
|
Frec. máxima interna & 500 MHz & 250 MHz & 250 MHz & 350 MHz & 350 MHz \\
|
280 |
|
|
\hline
|
281 |
|
|
Voltaje & 1.5 V & 2.5 V, 3.3 V & 3.3 V, 5 V & 2.5 V, 3.3 V, 5 V & 2.5 V, 3.3 V, 5 V \\
|
282 |
|
|
\hline
|
283 |
|
|
Inter\-conexiones & \textsl{Antifuse} & \textsl{Flash} & \textsl{Antifuse} & \textsl{Antifuse} & \textsl{Antifuse}\\
|
284 |
|
|
\hline
|
285 |
|
|
\multirow{3}{*}{Tecnología} & 0.15 $\mu$m & .22 $\mu$m & 0.45 $\mu$m & 0.22 $\mu$m & 0.22 $\mu$m \\
|
286 |
|
|
& 7 capas de metal & 4 capas de metal & 3 capas de metal & & \\
|
287 |
|
|
& CMOS & CMOS & CMOS & CMOS &CMOS \\
|
288 |
|
|
\hline
|
289 |
|
|
SRAM bits & 29 k -- 339 k & 14 k -- 198 k & 2.56 k & n.a. & n.a. \\
|
290 |
|
|
\hline
|
291 |
|
|
\end{tabular}
|
292 |
|
|
} % END \footnotesize{} segmentation
|
293 |
|
|
\caption{Características de FPGAs fabricadas por Actel.}
|
294 |
208 |
guanucolui |
\label{tab:char-fpga-actel}
|
295 |
128 |
guanucolui |
\end{table}
|
296 |
125 |
guanucolui |
|
297 |
128 |
guanucolui |
Nótese que todas las FPGAs de Xilinx usan SRAM para almacenar las interconexiones, por lo que son reprogramables, pero volátiles (es así que requieren de una ROM externa). en cambio, las FPGAs de Actel son no-volátiles (estos usan fusibles electrónicos), pero no son reprogramables (excepto una familia, la cual usa memoria \textsl{Flash}). Ya que cada enfoque tiene sus propias ventajas y desventajas, la aplicación real dictará cual arquitectura de chip es la apropiada.
|
298 |
125 |
guanucolui |
|
299 |
128 |
guanucolui |
\nomenclature[z-pal]{PAL}{\textsl{Programmable Array Logic}} % first letter Z is for Acronyms
|
300 |
|
|
\nomenclature[z-ff]{FF}{flip-flop, circuito que tiene dos estados estables y puede ser usado para almacenar información}
|
301 |
|
|
\nomenclature[z-palce]{PALCE}{\textsl{PAL CMOS Electrically erasable/programmable}}
|
302 |
|
|
\nomenclature[z-cpld]{CPLD}{\textsl{Complex Programmable Logic Device}}
|
303 |
|
|
\nomenclature[z-fpga]{FPGA}{\textsl{Field Programmable Gate Array}}
|
304 |
|
|
\nomenclature[z-eeprom]{EEPROM}{\textsl{Electrically Erasable Programmable Read-Only Memory}}
|
305 |
|
|
\nomenclature[z-clb]{CLB}{\textsl{Configurable Logic Block}}
|
306 |
|
|
\nomenclature[z-sram]{SRAM}{\textsl{Static-RAM}}
|
307 |
|
|
\nomenclature[z-pll]{PLL}{\textsl{Phase-Locked Loop}}
|
308 |
|
|
\nomenclature[z-dll]{DLL}{\textsl{Delay-Locked Loop}}
|
309 |
|
|
\nomenclature[z-pci]{PCI}{\textsl{Peripheral Component Interconnect}}
|
310 |
|
|
\nomenclature[z-dsp]{DSP}{\textsl{Digital Signal Processor}}
|
311 |
|
|
|
312 |
|
|
|
313 |
208 |
guanucolui |
\section{Lenguajes Descriptivos de \textsl{Hardware}}
|
314 |
|
|
\label{sec:fund-hdl}
|
315 |
128 |
guanucolui |
|
316 |
249 |
guanucolui |
La forma tradicional de diseñar circuitos digitales es dibujar diagramas lógicos que contengan compuertas (SSI) y funciones lógicos (MSI). Sin embargo, a fines de 1980s y comienzo de 1990s este proceso de diseño presentaba limitaciones como así algunos problemas. \emph{¿Como se puede dibujar diagramas esquemáticos que contienen cientos de miles o millones de compuertas?} Con la disponibilidad de los dispositivos lógicos programables para reemplazar sistemas donde se utilizaban integrados como los TTL, un nuevo enfoque para el diseño digital fue necesario. Las herramientas asistidas por computadoras son esenciales para diseñar circuitos digitales en la actualidad. Es claro que en las últimas décadas los ingenieros digitales de hoy diseñan sistemas digitales mediante la utilización de \textsl{software}! Esto es un importante cambio de paradigma del tradicional método empleado para el diseño de sistemas digitales.
|
317 |
|
|
|
318 |
|
|
Actualmente los diseñadores digitales usan \emph{Lenguajes Descriptivos de \textsl{Hardware}} (HDLs) para diseñar sistemas digitales. Los lenguajes más utilizados son \emph{VHDL} y \emph{Verilog}. Ambos lenguajes descriptivos permiten al usuario diseñar sistemas digitales mediante la escritura de código que describen el comportamiento de un circuito digital. Este código puede ser utilizado tanto para \emph{simular} la operación del circuito y \emph{sintetizar} también implementarse dicho circuito en un CPLD, una FPGA o en un circuito integrado de aplicaciones específica (ASCI).
|
319 |
|
|
|
320 |
|
|
\subsection{VHDL}
|
321 |
|
|
\label{sec:fund-hdl-vhdl}
|
322 |
|
|
|
323 |
253 |
guanucolui |
El lenguaje VHDL surgió como parte de un programa norteamericano denominado \textsl{Very High Speed Integrated Circuits} (VHSIC), a comienzos de 1980. En el desarrollo de la ejecución de este programa surgió la necesidad de contar con un lenguaje que permita describir la estructura y funciones para los circuitos integrados (ICs). Es así que el VHSIC \textsl{Hardware Description Language} (VHDL) fue desarrollado. Luego la IEEE adoptaría como un lennguaje estándar en los Estados Unidos.
|
324 |
249 |
guanucolui |
|
325 |
253 |
guanucolui |
VHDL fue diseñado para cubrir necesidades el proceso de diseño. Primero, este lenguaje permite la descripción de la estructura de un diseño, de esta forma se puede descomponer en sub-diseños, y a la vez como estos sub-diseños se interconectan entre sí. Segundo, VHDL permite la especificación de la función de los diseños usando las formas del lenguaje de programación similares a otros lenguajes familiares. Tercero, permite a un diseño ser simulado antes de ser fabricado, por lo que los diseñadores puede rápidamente compara alternativas y probar correciones sin el retardo y espera de los prototipos en \textsl{hardware}.
|
326 |
249 |
guanucolui |
|
327 |
|
|
\subsection{Verilog}
|
328 |
|
|
\label{sec:fund-hdl-verilog}
|
329 |
|
|
|
330 |
253 |
guanucolui |
Verilog esta basado en el lenguaje de programación C en la estructura de la sintaxis pero la manera en la que se comporta es diferentes pues es un lenguaje descriptivo.
|
331 |
|
|
|
332 |
249 |
guanucolui |
\nomenclature[z-ssi]{SSI}{\textsl{Small Scale Integration}} % first letter Z is for Acronyms
|
333 |
|
|
\nomenclature[z-msi]{MSI}{\textsl{Medium Scale Integration}} % first letter Z is for Acronyms
|
334 |
|
|
|
335 |
208 |
guanucolui |
\section{Diseño de sistemas digitales}
|
336 |
|
|
\label{sec:fund-sist-digitales}
|
337 |
125 |
guanucolui |
|
338 |
208 |
guanucolui |
\section{Influencia de la Programabilidad}
|
339 |
|
|
\label{sec:infl-program}
|
340 |
125 |
guanucolui |
|
341 |
221 |
guanucolui |
En muchos textos la ley de Moore es usada para destacar la evolución de la tecnología de silicio en la industria de los dispositivos semiconductores. Poro hay otro interesante punto de vista particularmente para los dispositivos PLDs, la \emph{onda de Makimoto} que fue publicada por primera vez en Enero de 1991 por la revista \textsl{Electronics Weekly}. Este concepto se basa en la observación de Tsugio Makimoto quién notó que la tecnología se desplazaba entre la \emph{estandarización} y la \emph{personalización} (véase la Figura \ref{fig:makimoto-wave}). En el comienzo de la década de 1960s, un número de componentes estándares fueron desarrollados, llamados series lógicas 7400 (por Texas Instruments). Dispositivos que servían para crear diversas aplicaciones digitales. Entrada la década de 1970s, la época de los dispositivos personalizados (LSI, siglas en inglés de \textsl{Low-Scape Integration}) comenzó a desarrollarse donde los chips eran creados para aplicaciones específicas como ser una calculadora. El chip fue incrementando su nivel de integración y así fue que nació el termino integración a media escala (MSI, siglas en inglés de \textsl{Medium-Scale Integration}). La evolución de los microprocesadores en la década de 1970s llevó a la estandarización de chips que fueran usados para un amplio rango de aplicaciones. Es entonces que en 1980s nació el ASIC (\textsl{Application-Specific Integrated Circuit}) donde el diseñador podría superar la limitación de la secuencialidad de los microprocesadores, quienes poseían varias limitaciones en aplicaciones en DSP (\textsl{Digital Signal Processing}) donde se requería un mayor nivel de cálculos. La aparición de la FPGA como un dispositivo con la capacidad de proporcionar recursos lógicos necesarios para conectar varios componentes entre sí llevo a que se conviertan en dispositivos populares.
|
342 |
125 |
guanucolui |
|
343 |
216 |
guanucolui |
\begin{figure}
|
344 |
|
|
\centering
|
345 |
|
|
\includegraphics[width=0.8\textwidth]{makimoto-wave}
|
346 |
|
|
\caption{Onda de Makimoto.}
|
347 |
221 |
guanucolui |
\label{fig:makimoto-wave}
|
348 |
216 |
guanucolui |
\end{figure}
|
349 |
125 |
guanucolui |
|
350 |
244 |
guanucolui |
Se podría considerar la existencia de dos épocas de la \emph{programabilidad} donde la \emph{primera} época ocurre con la aparición del microprocesador en la década de 1970s, donde los programadores desarrollan soluciones programables basados sobre estos \textsl{hardware} fijos. El gran reto en esta época fue en entorno de \textsl{software}; los desarrolladores trabajaban con lenguajes \textsl{assembly} e incluso cuando los compiladores y ensambladores surgieron para el lenguaje C, pues se obtenían mejores rendimientos con la codificación manual. Se comenzaron a obtener librerías que proporcionaban funciones básicas, permitiendo al diseñador concentrarse en la programación de la aplicación. Estas funciones actualmente son fácilmente accedidas desde los compiladores y ensambladores comerciales/libres. Actualmente hay una gran demanda de lenguajes de programación de alto-nivel como C y Java. Tal es así la abstracción del lenguaje que incluso entornos de desarrollos de alto nivel como UML están siendo implementados.
|
351 |
125 |
guanucolui |
|
352 |
244 |
guanucolui |
La \emph{segunda} época de la programabilidad se encuentra marcada por las FPGAs. En la Figura \ref{fig:makimoto-wave}, Makimoto indica que el campo de la programabilidad se estandariza para su fabricación y la personalización del diseño se encuentra en la capa de aplicación de un desarrollo con las tecnologías mencionadas. Esto puede ser considerado como lo que ofrece la programabilidad de \textsl{hardware} en el dominio del \textsl{software} donde el \textsl{hardware} permanece fijo. Esto es un reto fundamental como la mayoría de las herramientas de programación de computadora que trabajan sobre el principio de una plataforma de \textsl{hardware} fijo, lo que permite realizar optimizaciones ya que hay una orientación clara sobre la manera de mejorar el rendimiento de una representación algorítmica. Con las FPGAs, el usuario tiene plena libertad para definir la arquitectura que mejor se adapte a la aplicación. Sin embargo, esto presenta un problema en el que cada solución debe ser \emph{hecha a mano} y todos los diseñadores de \textsl{hardware} conocen los problemas en el diseño y verificación.
|
353 |
221 |
guanucolui |
|
354 |
249 |
guanucolui |
Algunas de las tendencias en las dos épocas tienen similitudes. En los primeros días, el modo esquemático (\textsl{schematic capture}) fue usado para diseñar los primeros circuitos que era sinónimo con el nivel \textsl{assembly} en programación. Los lenguajes de descripción de \textsl{hardware} como el VHDL y Verilog emergieron ya que podrían ser utilizados para producir un nivel de abstracción más alto con el objetivo de contar con una herramienta basada en C como son SystemC y CataultC de Mentor Graphics como un entorno único de programación. Inicialmente como con los lenguajes de programación de \textsl{software}, había una desconfianza en la calidad de los resultados que producía el código con este nuevo enfoque. Sin embargo, con el fin de mejorar los costos de desarrollo, las herramientas de síntesis que eran equivalentes a la evolución de los compiladores de \textsl{software} eficientes para los lenguaje de alto-nivel, y también la evolución de las funciones de librería, estableció un alto grado de confianza que posteriormente llevó al uso de los lenguajes descriptivos de \textsl{hardware} (HDLs) sean comnues para la implementación en FPGA. En efecto, el surgimiento de los IP-cores refleja la evolución de librerías como son funciones programables de entradas/salidas para el flujo del \textsl{software} donde funciones comunes fueron reutilizadas donde los desarrolladores confiaban en la calidad de los resultados que producían estas librerías, especialmente en lo que las presiones para producir más código en el mismo lapso de tiempo crecieron con la evolución tecnológica. Los primeros IP-cores surgieron a partir de funciones de librerías básicas en el procesamiento de señales complejas y funciones de comunicación la mayoría de estos suministrados por los proveedores de FPGA y diversos repositorios web de IP-cores.
|
355 |
244 |
guanucolui |
|
356 |
208 |
guanucolui |
% Aquí se podría poner algo sobre el paper "The Role of the Laboratory in Undergraduate Engineering Education".
|
357 |
|
|
|
358 |
|
|
|
359 |
|
|
%\begin{landscape}
|
360 |
|
|
|
361 |
|
|
% \section*{Subplots}
|
362 |
|
|
% I can cite Wall-E (see Fig.~\ref{fig:WallE}) and Minions in despicable me (Fig.~\ref{fig:Minnion}) or I can cite the whole figure as Fig.~\ref{fig:animations}
|
363 |
|
|
|
364 |
|
|
% \begin{figure}
|
365 |
|
|
% \centering
|
366 |
|
|
% \subfloat[A Tom and Jerry]{\label{fig:TomJerry}\includegraphics[width=0.3\textwidth]{TomandJerry}}
|
367 |
|
|
% \subfloat[A Wall-E]{\label{fig:WallE}\includegraphics[width=0.3\textwidth]{WallE}}
|
368 |
|
|
% \subfloat[A Minion]{\label{fig:Minnion}\includegraphics[width=0.3\textwidth]{minion}}
|
369 |
|
|
% \caption{Best Animations}
|
370 |
|
|
% \label{fig:animations}
|
371 |
|
|
% \end{figure}
|
372 |
|
|
|
373 |
|
|
|
374 |
|
|
% \end{landscape}
|