<!DOCTYPE html>
<html lang="es">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta name="generator" content="Asciidoctor 2.0.17">
<meta name="keywords" content="computer, architecture">
<meta name="author" content="Cándido Aramburu">
<title>Estructura de Computadores  (240306)</title>
<style>
@import "https://fonts.googleapis.com/css?family=Open+Sans:300,300italic,400,400italic,600,600italic%7CNoto+Serif:400,400italic,700,700italic%7CDroid+Sans+Mono:400,700";
@import "https://cdn.jsdelivr.net/gh/asciidoctor/asciidoctor@2.0/data/stylesheets/asciidoctor-default.css";



h1, h2, h3, h4, h5, h6, #toctitle,
.sidebarblock > .content > .title {
  color: rgba(221, 72, 20, 0.8);
}



</style>
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/4.7.0/css/font-awesome.min.css">
<!-- Change some CSS.
<style>
.imageblock{
  &.text-center > .title {
    text-align: center !important;
  }
}
</style>

-->

<style type="text/css"> .imageblock > .title { text-align: center; } </style>

<style>.toc-current{font-weight: bold;} .toc-root{font-family: "Open Sans","DejaVu Sans",sans-serif;
                       font-size: 0.9em;} #content{display: flex; flex-direction: column; flex: 1 1 auto;}
             .nav-footer{text-align: center; margin-top: auto;}
             .nav-footer > p > a {white-space: nowrap;}</style>
</head>
<body id="_rtl_register_transfer_language" class="book">
<div id="header">
<h1>Estructura de Computadores  (240306)</h1>
<div class="details">
<span id="author" class="author">Cándido Aramburu</span><br>
<span id="email" class="email"><a href="mailto:candido@unavarra.es">candido@unavarra.es</a></span><br>
<span id="revdate">2022-09-06</span>
</div>
<div id="toc" class="toc">
<div id="toctitle">Table of Contents</div>
<p><span class="toc-root"><a href="eecc_book.html">Estructura de Computadores  (240306)</a></span></p><ul class="sectlevel0">
<li><a href="_i_arquitectura_del_repertorio_de_instrucciones_isa_computadora_von_neumann_datos_instrucciones_programación.html">I Arquitectura del Repertorio de Instrucciones (ISA): computadora von Neumann, datos, instrucciones, programación.</a>
</li>
<li><a href="_ii_unidades_básicas_procesador_central_unidad_de_memoria_mecanismos_entradasalida.html">II Unidades Básicas: Procesador Central, Unidad de Memoria, Mecanismos Entrada/Salida.</a>
</li>
<li><a href="_iii_ejercicios_de_teoría.html">III Ejercicios de Teoría</a>
</li>
<li><a href="_iv_autoevaluación_teoría.html">IV Autoevaluación Teoría</a>
</li>
<li><a href="_v_guiones_de_prácticas_programación_ensamblador_x86.html">V Guiones de Prácticas: Programación Ensamblador x86</a>
</li>
<li><a href="_vi_hojas_de_referencia_rápida.html">VI Hojas de Referencia Rápida</a>
</li>
<li><a href="_vii_autoevaluación_prácticas.html">VII Autoevaluación Prácticas</a>
</li>
<li><a href="_viii_apéndices.html">VIII Apéndices</a>
<ul class="sectlevel1">
<li><a href="_programas_ensamblador_iassim.html">21. Programas ensamblador IASSim</a>
</li>
<li><a href="_simulador_iassim_2.html">22. Simulador IASSim</a>
</li>
<li><a href="_lenguajes_ensamblador.html">23. Lenguajes Ensamblador</a>
</li>
<li><a href="_lenguajes_de_programación_para_sum1ton.html">24. Lenguajes de programación para sum1toN</a>
</li>
<li><a href="_rtl_register_transfer_language.html"><span class="toc-current">25. RTL Register Transfer Language</span></a>
<ul class="sectlevel2">
<li><a href="_rtl_register_transfer_language.html#RTL_lang">25.1. Lenguaje RTL</a>
<ul class="sectlevel3">
<li><a href="_rtl_register_transfer_language.html#_introducción_22">25.1.1. Introducción</a>
</li>
<li><a href="_rtl_register_transfer_language.html#_registros_4">25.1.2. Registros</a>
</li>
<li><a href="_rtl_register_transfer_language.html#_símbolos">25.1.3. Símbolos</a>
</li>
<li><a href="_rtl_register_transfer_language.html#_sentencias_rtl">25.1.4. Sentencias RTL</a>
</li>
<li><a href="_rtl_register_transfer_language.html#_ejemplos_rtl_con_expresiones_aritmetico_lógicas">25.1.5. Ejemplos RTL con expresiones aritmetico-lógicas</a>
</li>
</ul>
</li>
</ul>
</li>
<li><a href="_formato_de_instrucción_isa_intel_x86_64_2.html">26. Formato de Instrucción: ISA Intel x86-64</a>
</li>
<li><a href="_fpu_x87.html">27. FPU x87</a>
</li>
<li><a href="_pila.html">28. Pila</a>
</li>
<li><a href="_llamadas_al_sistema_operativo_2.html">29. Llamadas al Sistema Operativo</a>
</li>
<li><a href="_lenguaje_de_programación_c_2.html">30. Lenguaje de Programación C</a>
</li>
<li><a href="_apéndice_prácticas.html">31. Apéndice Prácticas</a>
</li>
<li><a href="_arquitectura_amd64_4.html">32. Arquitectura amd64</a>
</li>
<li><a href="_exámenes_de_cursos_anteriores.html">33. Exámenes de Cursos Anteriores</a>
</li>
<li><a href="_miaulario_videoconferencia.html">34. Miaulario: Videoconferencia</a>
</li>
</ul>
</li>
<li><a href="_ix_bibliografía.html">IX Bibliografía</a>
</li>
<li><a href="_x_glosario.html">X Glosario</a>
</li>
<li><a href="_xi_colofón.html">XI Colofón</a>
</li>
<li><a href="_index.html">Index</a>
</li>
</ul>
</div>
</div>
<div id="content">
<div class="sect1">
<h2 id="_rtl_register_transfer_language">25. RTL Register Transfer Language</h2>
<div class="sectionbody">
<div class="sect2">
<h3 id="RTL_lang">25.1. Lenguaje RTL</h3>
<div class="sect3">
<h4 id="_introducción_22">25.1.1. Introducción</h4>
<div class="ulist">
<ul>
<li>
<p>Lenguaje de descripción de INSTRUCCIONES: Register Transfer Language (RTL)</p>
</li>
<li>
<p>El lenguaje RTL tiene como objetivo poder expresar las instrucciones que ejecuta la CPU como sumar(ADD),restar(SUB),mover(MOV), etc. La descripción se realiza a nivel de transferencia de datos entre <em>registros</em> internos de la CPU o entre registros internos y la memoria externa.</p>
</li>
<li>
<p>El lenguaje RTL , mediante símbolos interpretables por el programador, permite describir su comportamiento a nivel hardware y así definir el diseño de la arquitectura de una máquina.</p>
</li>
<li>
<p>Los <em>registros</em> son el elemento fundamental de memoria en la ruta de los datos e instrucciones entre las distintas unidades básicas de la computadora. Un registro es un circuito digital que almacena, memoriza, un dato.</p>
</li>
<li>
<p>La ruta de los datos está formada por los buses y los elementos (<em>registros</em>, multiplexores, switches, contadores, etc ) que se conectan a través de los buses</p>
<div class="ulist">
<ul>
<li>
<p>Ejemplo: ruta de un dato desde una posición de la memoria principal hacia los registros de operando de la ALU.</p>
</li>
<li>
<p>Concepto de buffer: etapa intermedia de memoria en la ruta de los datos.</p>
</li>
</ul>
</div>
</li>
<li>
<p>La ejecución de las instrucciones que ejecuta la CPU implica la transferencia de datos a través de los registros de la ruta de datos.</p>
</li>
</ul>
</div>
<div class="admonitionblock caution">
<table>
<tr>
<td class="icon">
<i class="fa icon-caution" title="Caution"></i>
</td>
<td class="content">
No confundir el RTL (Register Transfer Language) con el RTL (Register Transfer Level). El Register Transfer Level es utilizado por los lenguajes de descripción de HARDWARE (Hardware Description Language HDL)
</td>
</tr>
</table>
</div>
</div>
<div class="sect3">
<h4 id="_registros_4">25.1.2. Registros</h4>
<div class="sect4">
<h5 id="_arquitectura_4">Arquitectura</h5>
<div class="ulist">
<ul>
<li>
<p>La arquitectura de un registro comprende su funcionalidad y la estructura su implementación</p>
</li>
<li>
<p>Los registros:</p>
<div class="ulist">
<ul>
<li>
<p><em>almacenan</em> una palabra formada por una secuencia de bits.</p>
</li>
<li>
<p>son una array de celdas en una dimensión, donde cada celda almacena un bit.</p>
</li>
</ul>
</div>
</li>
<li>
<p>Su tamaño normalmente es un múltiplo de 8 bytes y recibe un nombre.</p>
<div class="ulist">
<ul>
<li>
<p>8 bits: 1 Byte</p>
</li>
<li>
<p>16 bits: Word. Por razones históricas.(recordad que el tamaño de una palabra en otro contexto depende de la máquina de que se trate)</p>
</li>
<li>
<p>32 bits: double word</p>
</li>
<li>
<p>64 bits: quad word</p>
</li>
</ul>
</div>
</li>
<li>
<p>Las celdas se enumeran empezando por cero.</p>
<div class="ulist">
<ul>
<li>
<p>LSB: Least Significant Bit es el bit de menor peso</p>
</li>
<li>
<p>MSB: Most Significant Bit es el bit de mayor peso</p>
<div class="imageblock kroki">
<div class="content">
<img src="https://kroki.io/ditaa/svg/eNrj0tbV1cWLuWoUzBVqFBRwYAOFGi7CZij4Bjsp4AI-wU5chM0gwp2GprjdSQgT5Q_K_EkIgMOBOgEB8RCcNkDiGxIWHwQBAQD7T3V7" alt="Diagram">
</div>
</div>
</li>
</ul>
</div>
</li>
</ul>
</div>
</div>
<div class="sect4">
<h5 id="_estructura_5">Estructura</h5>
<div class="ulist">
<ul>
<li>
<p>La  estructura del registro es la implementación de su funcionalidad</p>
</li>
<li>
<p>Cada bit del dato a registrar se almacena en una celda con capacidad de memoria. Las celdas de un registro se implementan con un circuito digital denominado flip-flop. Cada flip-flop almacena un bit.</p>
</li>
</ul>
</div>
<div class="imageblock kroki">
<div class="content">
<img src="https://kroki.io/ditaa/svg/eNpTUAAD54zMAoXg1JzU5BIFDedgTS4FZFCDyi1D4mrrgoA2kkgNhhYaiHjmFZSWwEUU_EtLgHwusHP0dXXtQBJBBkBSF8IHG2JohmQImE9vV-MMMwWFOCBCEahB0eOTn5gCjKWc_ORsLgDSnkvF" alt="Diagram">
</div>
</div>
<div class="ulist">
<ul>
<li>
<p>El registro está conectado al mundo exterior mediante buses: bus de entrada y bus de salida</p>
</li>
<li>
<p>CS: Chip Select : conecta la salida interna del registro R0 al bus de salida &#8594; Operación de lectura del registro</p>
</li>
<li>
<p>Load: Si la señal está activa se ordena la carga del valor del bus de entrada en el registro R0, se registra el dato de entrada. Operación de escritura en el registro.</p>
</li>
<li>
<p>Clock: señal digital binaria periódica.</p>
</li>
<li>
<p>La carga es síncrona con la señal de reloj clock CLK. El sincronismo se produce en los flancos positivos <em>_\|</em>  o negativos</p>
<div class="imageblock kroki">
<div class="content">
<img src="https://kroki.io/ditaa/svg/eNpTUICBEAVbBUP9NC4bXSzAjotLARVog8W1KRdFN7gGiaRIdLgYXEa56GgYIwzWRk3Z2khpkSJRLq7g1MMbE3MUUlIVilJz8rN0FJJz8pOz9bgA23yLzA==" alt="Diagram">
</div>
</div>
</li>
</ul>
</div>
</div>
</div>
<div class="sect3">
<h4 id="_símbolos">25.1.3. Símbolos</h4>
<div class="ulist">
<ul>
<li>
<p>Los nombres de los registros se expresan mediante mayúsculas</p>
<div class="ulist">
<ul>
<li>
<p>PC: Program Counter</p>
</li>
<li>
<p>IR: Instruction Regiter</p>
</li>
<li>
<p>R2: Registro 2</p>
</li>
</ul>
</div>
</li>
<li>
<p>Secciones de un registro</p>
<div class="ulist">
<ul>
<li>
<p>PC(L) : Byte de menor peso del registro contador de programa</p>
</li>
<li>
<p>PC(H) : Byte de mayor peso del registro contador de programa</p>
</li>
<li>
<p>PC(7:0): Secuencia de bits de la posición cero hasta la posición séptima del registro contador de programa.</p>
</li>
</ul>
</div>
</li>
</ul>
</div>
</div>
<div class="sect3">
<h4 id="_sentencias_rtl">25.1.4. Sentencias RTL</h4>
<div class="sect4">
<h5 id="_operaciones_y_sentencias_rtl">Operaciones y Sentencias RTL</h5>
<div class="ulist">
<ul>
<li>
<p>En lenguaje RTL entendemos por sentencia una expresión que implica realizar operaciones con los registros.</p>
</li>
<li>
<p>Operaciones RTL:</p>
<div class="ulist">
<ul>
<li>
<p>transferencias entre registros, suma del contenido de dos registros, invertir el contenido de un registro, etc</p>
</li>
</ul>
</div>
</li>
</ul>
</div>
</div>
<div class="sect4">
<h5 id="_microoperación">Microoperación</h5>
<div class="ulist">
<ul>
<li>
<p>MICROoperaciones: operaciones realizadas por el MICROprocesador internamente, al ejecutar una Instrucción Máquina.</p>
<div class="ulist">
<ul>
<li>
<p>Ejemplos: escribir en un registro, orden de lectura a la M.Principal, leer de un registro, Decodificar una instrucción, incrementar un contador, sumar (microordenes al circuito sumador), desplazamiento de los bits de un registro, lógica AND,  etc&#8230;&#8203;</p>
</li>
</ul>
</div>
</li>
<li>
<p>La operación de escribir en un registro o leer en un registro para la CPU es una microoperación.</p>
</li>
</ul>
</div>
</div>
<div class="sect4">
<h5 id="_transferencia_entre_registros">Transferencia entre registros</h5>
<div class="ulist">
<ul>
<li>
<p>Operador transferencia &#8592;</p>
</li>
<li>
<p>Sentencia transferencia: R2&#8592;R1</p>
<div class="ulist">
<ul>
<li>
<p>A R1 se le llama registro fuente y a R2 registro destino</p>
</li>
<li>
<p>Copiamos el contenido del registro R1 en el registro R2</p>
</li>
</ul>
</div>
</li>
</ul>
</div>
</div>
<div class="sect4">
<h5 id="_sentencia_condicional">Sentencia Condicional</h5>
<div class="ulist">
<ul>
<li>
<p>If (K1=1) then R2&#8592;R1</p>
<div class="ulist">
<ul>
<li>
<p>K1:R2&#8592;R1</p>
</li>
<li>
<p>La transferencia o copia se realiza únicamente si K1 es verdad es decir K1 vale el valor lógico 1.</p>
</li>
</ul>
</div>
</li>
</ul>
</div>
</div>
<div class="sect4">
<h5 id="_sentencia_concurrente">Sentencia Concurrente</h5>
<div class="ulist">
<ul>
<li>
<p>Operador coma</p>
</li>
<li>
<p>K3:R2&#8592;R1,R3&#8592;R1</p>
<div class="ulist">
<ul>
<li>
<p>Si K3 es verdad el contenido de R1 se copia en R2 y R3</p>
</li>
</ul>
</div>
</li>
</ul>
</div>
</div>
<div class="sect4">
<h5 id="_referencia_a_la_memoria_principal">Referencia a la Memoria Principal</h5>
<div class="ulist">
<ul>
<li>
<p>Se utilizan los corchetes y el símbolo M.</p>
</li>
<li>
<p>M[0x80000] : contenido de la posición de memoria 0x8000</p>
</li>
<li>
<p>AC &#8592; M[0x80000] : copiar  el contenido de memoria de la posición 0x8000 al registro AC</p>
</li>
<li>
<p>AC &#8592; M[AC] : copiar el contenido de la posición de memoria a la que <strong>apunta</strong> el registro AC en el registro AC</p>
</li>
<li>
<p>M[0x8000] &#8592; AC: copiar el contenido del registro AC en la posición de Memoria 0x8000</p>
<div class="ulist">
<ul>
<li>
<p>M[0x8000] &#8592; R[AC]: copiar el contenido del registro AC en la posición de Memoria 0x8000</p>
</li>
</ul>
</div>
</li>
</ul>
</div>
</div>
<div class="sect4">
<h5 id="_left_right_value">Left-Right Value</h5>
<div class="ulist">
<ul>
<li>
<p>Este concepto se utiliza en el lenguaje C al definir la sentencia asignación <em>=</em></p>
</li>
<li>
<p>M[0x1000] &#8592; M[0x2000]</p>
<div class="ulist">
<ul>
<li>
<p>El contenido de la posición 0x2000 se copia en la posición 0x1000</p>
</li>
<li>
<p>Lo que hay a la derecha del operador &#8592; se evalua y se obtiene un VALOR</p>
</li>
<li>
<p>Lo que hay a la izda del operador &#8592; es una DIRECCION o REFERENCIA a Memoria (Principal o Registro)</p>
</li>
</ul>
</div>
</li>
</ul>
</div>
</div>
</div>
<div class="sect3">
<h4 id="_ejemplos_rtl_con_expresiones_aritmetico_lógicas">25.1.5. Ejemplos RTL con expresiones aritmetico-lógicas</h4>
<div class="ulist">
<ul>
<li>
<p>AC &#8592; R1 v R2</p>
<div class="ulist">
<ul>
<li>
<p>Operación lógica OR</p>
</li>
</ul>
</div>
</li>
<li>
<p>(K1+K2):R1 &#8592; R2+R3,R4&#8592;R5^R6</p>
<div class="ulist">
<ul>
<li>
<p>El símbolo <em>+</em> tiene dos significados: booleano o aritmético.</p>
<div class="ulist">
<ul>
<li>
<p>En k1+k2 tiene significado booleano: or. Aquí no tiene sentido la suma aritmética de señales lógicas. Tiene sentido evaluar si la señales están activas o no.</p>
</li>
<li>
<p>En R2+R3 tiene significado aritmético.</p>
</li>
</ul>
</div>
</li>
</ul>
</div>
</li>
<li>
<p>Para indicar prioridad en una expresión utilizaremos los paréntesis.</p>
</li>
</ul>
</div>
</div>
</div>
</div>
</div>
<div class="paragraph nav-footer">
<p>← Previous: <a href="_lenguajes_de_programación_para_sum1ton.html">Lenguajes de programación para sum1toN</a> | ↑ Up: <a href="_viii_apéndices.html">VIII Apéndices</a> | ⌂ Home: <a href="eecc_book.html">Estructura de Computadores  (240306)</a> | Next: <a href="_formato_de_instrucción_isa_intel_x86_64_2.html">Formato de Instrucción: ISA Intel x86-64</a> →</p>
</div>
</div>
<div id="footer">
<div id="footer-text">
Last updated 2022-09-05 10:43:18 +0200
</div>
</div>
</body>
</html>