16.2: Núcleo AVR Atmel
- Page ID
- 82010
\( \newcommand{\vecs}[1]{\overset { \scriptstyle \rightharpoonup} {\mathbf{#1}} } \)
\( \newcommand{\vecd}[1]{\overset{-\!-\!\rightharpoonup}{\vphantom{a}\smash {#1}}} \)
\( \newcommand{\id}{\mathrm{id}}\) \( \newcommand{\Span}{\mathrm{span}}\)
( \newcommand{\kernel}{\mathrm{null}\,}\) \( \newcommand{\range}{\mathrm{range}\,}\)
\( \newcommand{\RealPart}{\mathrm{Re}}\) \( \newcommand{\ImaginaryPart}{\mathrm{Im}}\)
\( \newcommand{\Argument}{\mathrm{Arg}}\) \( \newcommand{\norm}[1]{\| #1 \|}\)
\( \newcommand{\inner}[2]{\langle #1, #2 \rangle}\)
\( \newcommand{\Span}{\mathrm{span}}\)
\( \newcommand{\id}{\mathrm{id}}\)
\( \newcommand{\Span}{\mathrm{span}}\)
\( \newcommand{\kernel}{\mathrm{null}\,}\)
\( \newcommand{\range}{\mathrm{range}\,}\)
\( \newcommand{\RealPart}{\mathrm{Re}}\)
\( \newcommand{\ImaginaryPart}{\mathrm{Im}}\)
\( \newcommand{\Argument}{\mathrm{Arg}}\)
\( \newcommand{\norm}[1]{\| #1 \|}\)
\( \newcommand{\inner}[2]{\langle #1, #2 \rangle}\)
\( \newcommand{\Span}{\mathrm{span}}\) \( \newcommand{\AA}{\unicode[.8,0]{x212B}}\)
\( \newcommand{\vectorA}[1]{\vec{#1}} % arrow\)
\( \newcommand{\vectorAt}[1]{\vec{\text{#1}}} % arrow\)
\( \newcommand{\vectorB}[1]{\overset { \scriptstyle \rightharpoonup} {\mathbf{#1}} } \)
\( \newcommand{\vectorC}[1]{\textbf{#1}} \)
\( \newcommand{\vectorD}[1]{\overrightarrow{#1}} \)
\( \newcommand{\vectorDt}[1]{\overrightarrow{\text{#1}}} \)
\( \newcommand{\vectE}[1]{\overset{-\!-\!\rightharpoonup}{\vphantom{a}\smash{\mathbf {#1}}}} \)
\( \newcommand{\vecs}[1]{\overset { \scriptstyle \rightharpoonup} {\mathbf{#1}} } \)
\( \newcommand{\vecd}[1]{\overset{-\!-\!\rightharpoonup}{\vphantom{a}\smash {#1}}} \)
\(\newcommand{\avec}{\mathbf a}\) \(\newcommand{\bvec}{\mathbf b}\) \(\newcommand{\cvec}{\mathbf c}\) \(\newcommand{\dvec}{\mathbf d}\) \(\newcommand{\dtil}{\widetilde{\mathbf d}}\) \(\newcommand{\evec}{\mathbf e}\) \(\newcommand{\fvec}{\mathbf f}\) \(\newcommand{\nvec}{\mathbf n}\) \(\newcommand{\pvec}{\mathbf p}\) \(\newcommand{\qvec}{\mathbf q}\) \(\newcommand{\svec}{\mathbf s}\) \(\newcommand{\tvec}{\mathbf t}\) \(\newcommand{\uvec}{\mathbf u}\) \(\newcommand{\vvec}{\mathbf v}\) \(\newcommand{\wvec}{\mathbf w}\) \(\newcommand{\xvec}{\mathbf x}\) \(\newcommand{\yvec}{\mathbf y}\) \(\newcommand{\zvec}{\mathbf z}\) \(\newcommand{\rvec}{\mathbf r}\) \(\newcommand{\mvec}{\mathbf m}\) \(\newcommand{\zerovec}{\mathbf 0}\) \(\newcommand{\onevec}{\mathbf 1}\) \(\newcommand{\real}{\mathbb R}\) \(\newcommand{\twovec}[2]{\left[\begin{array}{r}#1 \\ #2 \end{array}\right]}\) \(\newcommand{\ctwovec}[2]{\left[\begin{array}{c}#1 \\ #2 \end{array}\right]}\) \(\newcommand{\threevec}[3]{\left[\begin{array}{r}#1 \\ #2 \\ #3 \end{array}\right]}\) \(\newcommand{\cthreevec}[3]{\left[\begin{array}{c}#1 \\ #2 \\ #3 \end{array}\right]}\) \(\newcommand{\fourvec}[4]{\left[\begin{array}{r}#1 \\ #2 \\ #3 \\ #4 \end{array}\right]}\) \(\newcommand{\cfourvec}[4]{\left[\begin{array}{c}#1 \\ #2 \\ #3 \\ #4 \end{array}\right]}\) \(\newcommand{\fivevec}[5]{\left[\begin{array}{r}#1 \\ #2 \\ #3 \\ #4 \\ #5 \\ \end{array}\right]}\) \(\newcommand{\cfivevec}[5]{\left[\begin{array}{c}#1 \\ #2 \\ #3 \\ #4 \\ #5 \\ \end{array}\right]}\) \(\newcommand{\mattwo}[4]{\left[\begin{array}{rr}#1 \amp #2 \\ #3 \amp #4 \\ \end{array}\right]}\) \(\newcommand{\laspan}[1]{\text{Span}\{#1\}}\) \(\newcommand{\bcal}{\cal B}\) \(\newcommand{\ccal}{\cal C}\) \(\newcommand{\scal}{\cal S}\) \(\newcommand{\wcal}{\cal W}\) \(\newcommand{\ecal}{\cal E}\) \(\newcommand{\coords}[2]{\left\{#1\right\}_{#2}}\) \(\newcommand{\gray}[1]{\color{gray}{#1}}\) \(\newcommand{\lgray}[1]{\color{lightgray}{#1}}\) \(\newcommand{\rank}{\operatorname{rank}}\) \(\newcommand{\row}{\text{Row}}\) \(\newcommand{\col}{\text{Col}}\) \(\renewcommand{\row}{\text{Row}}\) \(\newcommand{\nul}{\text{Nul}}\) \(\newcommand{\var}{\text{Var}}\) \(\newcommand{\corr}{\text{corr}}\) \(\newcommand{\len}[1]{\left|#1\right|}\) \(\newcommand{\bbar}{\overline{\bvec}}\) \(\newcommand{\bhat}{\widehat{\bvec}}\) \(\newcommand{\bperp}{\bvec^\perp}\) \(\newcommand{\xhat}{\widehat{\xvec}}\) \(\newcommand{\vhat}{\widehat{\vvec}}\) \(\newcommand{\uhat}{\widehat{\uvec}}\) \(\newcommand{\what}{\widehat{\wvec}}\) \(\newcommand{\Sighat}{\widehat{\Sigma}}\) \(\newcommand{\lt}{<}\) \(\newcommand{\gt}{>}\) \(\newcommand{\amp}{&}\) \(\definecolor{fillinmathshade}{gray}{0.9}\)El núcleo del procesador Atmel AVR utiliza la arquitectura Harvard con canalización simple. A continuación se muestra un diagrama de bloques del núcleo de la serie AVR.
Lo primero que hay que notar es que la mayoría de los bloques están interconectados a través de un bus de datos de ocho bits (es decir, una colección de conexiones paralelas, en este caso, ocho de ellas). El bus de datos es bidireccional, lo que significa que los datos pueden ser colocados en él (escritos) por un bloque y extraídos (leídos) por otro. Obviamente, se necesita aplicar alguna forma de “control de tráfico” y que generalmente se maneja mediante señales de temporización apropiadas y búferes de tres estados 1.
La ALU, o Unidad Lógica Aritmética, es responsable de funciones computacionales básicas como suma y resta de enteros, operaciones de bits, comparaciones y similares. En asociación con esto hay 32 registros de propósito general de ocho bits. La ALU realiza operaciones sobre los valores en los registros, no directamente sobre los valores en la memoria general. Por ejemplo, supongamos que desea agregar dos variables y colocar el resultado en una tercera variable. La ALU tiene que transferir valores de la memoria a los registros donde se realiza el cálculo y luego transferir el resultado a la ubicación final. Una gran cantidad de registros es una característica común de los procesadores RISC. Los primeros procesadores CISC tenían muy pocos registros (de hecho, muchos tenían un solo “acumulador” para este tipo de operaciones). También hay muchos registros especializados que no se muestran aquí ya que están asociados con módulos IO, temporizadores, etc. (más sobre esto en un momento). Tres registros especializados importantes son el registro de estado, el contador de programas y el puntero de pila. El contador de programas (PC) realiza un seguimiento de la instrucción actualmente en ejecución (es decir, la ubicación actual del flujo de código). El puntero de pila (SP) registra la dirección de memoria actual de la parte superior de la pila (es decir, la ubicación en la memoria utilizada para variables temporales y similares). El registro de estado (SR) contiene una serie de bits que reflejan los resultados más recientes de una operación ALU y el estado general del procesador. El registro de estado AVR contiene ocho bits, todos los cuales son de lectura/escritura e inicializados en 0:
Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
---|---|---|---|---|---|---|---|---|
Función | I | T | H | S | V | N | Z | C |
Los bits son los siguientes de la documentación de Atmel:
Bit 7 — I: Habilitación de interrupción global
El bit Global Interrupt Enable debe establecerse para que las interrupciones estén habilitadas. El control de habilitación de interrupción individual se realiza entonces en registros de control separados. Si se borra el Registro de activación de interrupción global, ninguna de las interrupciones se habilita independientemente de la configuración de activación de interrupción individual. El bit I es borrado por el hardware después de que se haya producido una interrupción, y es establecido por la instrucción RETI para habilitar interrupciones posteriores. El bit I también puede ser establecido y borrado por la aplicación con las instrucciones SEI y CLI, como se describe en la referencia del conjunto de instrucciones.
Bit 6 — T: Almacenamiento de copia de bits
Las instrucciones Bit Copy BLD (Bit Load) y BST (Bit Store) utilizan el bit T como origen o destino para el bit operado. Un poco de un registro en el Archivo de Registro se puede copiar en T por la instrucción BST, y un bit en T se puede copiar en un bit en un registro en el Archivo de Registro por la instrucción BLD.
Bit 5 — H: Bandera de Medio Transporte
La Bandera de Medio Carry H indica un Medio Carry en algunas operaciones aritméticas. Half Carry Es útil en aritmética BCD.
Bit 4 — S: Bit de signo,\ (S = N\ oplus\ oplus V)\
El bit S siempre es exclusivo o entre el Indicador Negativo N y el Indicador de Desbordamiento del Complemento Dos V.
Bit 3 — V: Indicador de desbordamiento de complemento de dos
El indicador V de desbordamiento de complemento de dos admite aritmética de complemento de dos.
Bit 2 — N: Indicador negativo
El Indicador Negativo N indica un resultado negativo en una operación aritmética o lógica.
Bit 1 — Z: Indicador de cero
El Indicador de Cero Z indica un resultado cero en una operación aritmética o lógica.
Bit 0 — C: Bandera de transporte
El indicador de acarreo C indica un acarreo en una operación aritmética o lógica.
Es importante recordar que el estado del registro de estado no se guarda al ingresar a una rutina de interrupción o se restablece al regresar de una interrupción. Esto debe manejarse en software. Veremos cómo se maneja esto en futuros capítulos.
- Un búfer de tres estados simplemente repite su señal de entrada en su salida como un búfer ordinario pero también ofrece un tercer estado “Z alto”. Cuando se habilita el estado Z alto, no hay señal de salida presente y la impedancia de salida del búfer pasa a un valor muy alto, desconectando efectivamente el búfer del bus.