# UNIVERSIDAD TECNOLÓGICA DE PEREIRA

### FACULTAD DE INGENIERÍAS

Programa de Ingeniería de Sistemas y Computación

# Extensión para Visual Studio Code como simulador para procesador RISC-V

Autor:

Amir Evelio Hurtado Mena

**Código:** 1077997025

Email: a.hurtado@utp.edu.co

Director:

(Nombre del Director)

**Área Temática:** Ingeniería de Software **Línea de Investigación:** Desarrollo de Software Aplicado

Modalidad: Proyecto de Aplicación

#### Pereira, Colombia 17 de octubre de 2025

## ${\bf \acute{I}ndice}$

| 1.         | Introducción                                       | 2              |
|------------|----------------------------------------------------|----------------|
| 2.         | Planteamiento del problema                         | 2              |
|            | 2.1. Antecedentes (Contextualización del problema) | 2              |
|            | 2.2. Causas (qué está causando el problema)        | 3              |
|            | 2.3. Definición del problema                       | 4              |
|            | 2.4. Consecuencias (de no resolver el problema)    | $\overline{4}$ |
| 3.         | Justificación                                      | 4              |
|            | 3.1. Justificación Pedagógica y Académica          | 5              |
|            | 3.2. Justificación Tecnológica                     | 5              |
|            | 3.3. Justificación Institucional                   | 5              |
| 4.         | Objetivos                                          | 6              |
|            | 4.1. Objetivo General                              | 6              |
|            | 4.2. Objetivos específicos                         | 6              |
| <b>5</b> . | Marco Referencial                                  | 6              |
|            | 5.1. Marco Teórico                                 | 6              |
|            | 5.1.1. Arquitectura RISC-V                         | 6              |
|            | 5.1.2. Procesador Segmentado (Pipelined)           | 7              |
|            | 5.2 Estado del Arte                                | 7              |

#### 1. Introducción

La Arquitectura de Computadores es una materia fundamental en la carrera de Ingeniería de Sistemas y Computación, ya que permite entender cómo funciona el hardware que ejecuta todo el software que creamos. Sin embargo, los conceptos sobre el funcionamiento interno de un procesador, como los registros, las unidades de control y los ciclos de instrucción, suelen ser muy abstractos y dificiles de asimilar para los estudiantes que cursan la asignatura en la Universidad Tecnológica de Pereira.

Esta dificultad a menudo genera un obstáculo en el proceso de aprendizaje, ralentizando el avance de las clases y dejando vacíos conceptuales en los futuros profesionales. Para abordar este problema, este proyecto propone el desarrollo de una herramienta de software: una extensión para el editor de código Visual Studio Code que funciona como un simulador gráfico e interactivo de un procesador con arquitectura RISC-V, tanto en su versión monociclo como segmentada.

El objetivo es ofrecer a estudiantes y docentes un recurso que traduzca las operaciones complejas del procesador en visualizaciones claras y fáciles de seguir. De esta manera, se busca fortalecer la comprensión de los temas clave de la materia, haciendo el aprendizaje más práctico, intuitivo y efectivo, y mejorando así la calidad de la formación de los ingenieros de la universidad.

#### 2. Planteamiento del problema

#### 2.1. Antecedentes (Contextualización del problema)

La enseñanza de la Arquitectura de Computadores presenta desafios pedagógicos bien documentados en la literatura académica. Uno de los principales retos identificados es la dificultad para conectar la teoría con la práctica (Bridging Theory and Practice). Los estudiantes a menudo luchan por trasladar el conocimiento teórico a una aplicación tangible, lo que dificulta la comprensión de cómo se ejecutan los programas a nivel de sistema. Para abordar esto, varios autores proponen el uso de sistemas interactivos y laboratorios de aprendizaje asistido por computador (CAL) que permiten a los estudiantes visualizar la ejecución de programas e inspeccionar los detalles de implementación hasta el nivel de transferencia de registros ([1], [7]).

Otro desafio clave es la comprensión conceptual (Conceptual Understanding) de sistemas que son complejos e intangibles. Investigaciones señalan que muchos estudiantes, incluso de ciencias de la computación, tienen ideas erróneas fundamentales sobre cómo funcionan realmente los programas, un problema que requiere atención desde el diseño del currículo ([9]). En este contexto, el uso de herramientas de visualización de la ejecución se ha propuesto como una solución efectiva para ayudar a los estudiantes a comprender estos sistemas ([7]).

Por lo tanto, la literatura académica no solo confirma la existencia de estas barreras de aprendizaje, sino que también respalda el desarrollo de herramientas interactivas y visuales, como la propuesta en este proyecto, como un camino viable para mejorar significativamente la experiencia educativa en esta área fundamental.

#### 2.2. Causas (qué está causando el problema)

La causa principal del problema en la asignatura de Arquitectura de Computadores de la UTP es la brecha existente entre la teoría abstracta enseñada en clase y la falta de herramientas prácticas que permitan a los estudiantes visualizar y experimentar con dichos conceptos. Esta situación fue validada a través de una encuesta realizada a 57 estudiantes del programa que ya habían cursado la materia. Los resultados revelan la magnitud del desafío: un contundente 86 % de los estudiantes calificó el proceso de comprensión de la arquitectura de un computador y su implementación en hardware como Çomplejo.º "Muy complejo", lo que demuestra que no se trata de una percepción aislada, sino de una dificultad generalizada en el alumnado (Ver Gráfico 1).



Figura 1: Resultados sobre la complejidad percibida.

Más importante aún, la encuesta también indagó sobre la solución a esta dificultad. Al preguntarles sobre la necesidad de una nueva herramienta, la respuesta fue abrumadora: un 91.1 % de los estudiantes (sumando las categorías "Muy necesarioz "Necesario") afirmó que la inclusión de una herramienta tecnológica para visualizar los conceptos sería clave para un mejor aprendizaje (Ver Gráfico 2). Estos datos demuestran que la causa del problema no es una falta de interés por parte del alumnado, sino una necesidad directa y explícita de un recurso didáctico interactivo que les permita conectar los conceptos abstractos con una representación visual y práctica. La herramienta propuesta en este proyecto busca, por lo tanto, atacar directamente esta causa raíz.

Cómo consideraría la inclusión de una herramienta tecnológica en el curso de Arquitectura de Computadores para para ayudar a un mejor aprendizaje de los conceptos del curso? 58 respuestas



Figura 2: Necesidad de una herramienta tecnológica según los estudiantes.

#### 2.3. Definición del problema

Los estudiantes de la asignatura de Arquitectura de Computadores del programa de Ingeniería de Sistemas y Computación de la UTP presentan dificultades significativas para comprender los procesos internos de un procesador (monociclo y segmentado).

#### 2.4. Consecuencias (de no resolver el problema)

De no abordarse este problema, las consecuencias afectan a múltiples niveles. Para los estudiantes, implica una base conceptual débil que puede perjudicar su desempeño en materias posteriores que dependen de estos conocimientos, además de generar frustración y desinterés por el área del hardware. Para los docentes, significa tener que invertir más tiempo en reforzar conceptos básicos, ralentizando el avance del temario y limitando la posibilidad de profundizar en temas más avanzados. A largo plazo, para el programa académico, esto representa un riesgo en la calidad de la formación, ya que sus egresados podrían tener vacíos en un área fundamental de la ingeniería de sistemas, lo que podría impactar negativamente su perfil profesional en el mercado laboral.

#### 3. Justificación

La realización de este proyecto se justifica plenamente por su alto impacto en el proceso formativo de los estudiantes de Ingeniería de Sistemas y Computación de la UTP, así como por los aportes que ofrece tanto a los docentes como al programa académico. A continuación, se detallan los beneficios desde distintas perspectivas:

#### 3.1. Justificación Pedagógica y Académica

Este proyecto ataca directamente una barrera de aprendizaje validada. Como lo demostró la encuesta, el 86 % de los estudiantes considera complejo el proceso de comprensión de la materia, y un 91.1 % reclama una herramienta tecnológica para facilitar este proceso. Por lo tanto, el principal beneficio es para el estudiante, quien contará con un recurso interactivo diseñado para:

- Transformar lo abstracto en tangible: Permitirá visualizar el flujo de datos, el estado de los registros y la ejecución de instrucciones paso a paso, haciendo que los conceptos teóricos cobren vida.
- Fomentar el aprendizaje autónomo: Los estudiantes podrán experimentar y probar código a su propio ritmo, reforzando los conocimientos vistos en clase y resolviendo dudas de forma práctica.
- Aumentar la motivación y reducir la frustración: Al facilitar la comprensión, se espera un mayor interés por una de las áreas más fundamentales y áridas de la carrera.

Para los docentes, la herramienta se convertirá en un valioso recurso que les permitirá explicar temas complejos de manera más eficiente y gráfica, optimizando el tiempo en el aula y asegurando un nivel de comprensión más homogéneo en el grupo.

#### 3.2. Justificación Tecnológica

Desde el punto de vista tecnológico, el proyecto es relevante por el desarrollo de una solución de software específica y moderna. La creación de una extensión para Visual Studio Code, uno de los editores de código más utilizados en el mundo profesional, asegura que la herramienta se integre de forma natural en el entorno de trabajo de los estudiantes. Además, el enfoque en la arquitectura RISC-V, un estándar abierto y en pleno auge, garantiza que el conocimiento adquirido a través del simulador sea actual y pertinente para el futuro de la industria del hardware.

#### 3.3. Justificación Institucional

Para el programa de Ingeniería de Sistemas y Computación de la UTP, este proyecto representa una oportunidad para fortalecer sus métodos de enseñanza. La implementación de esta herramienta demuestra un compromiso con la mejora continua de la calidad educativa y con la atención a las necesidades de sus estudiantes. En resumen, este trabajo no solo resuelve un problema académico concreto y medido, sino que también aporta una solución tecnológica moderna y fortalece el ecosistema de aprendizaje del programa, generando un beneficio claro para toda la comunidad universitaria involucrada.

#### 4. Objetivos

#### 4.1. Objetivo General

Desarrollar una extensión de software para Visual Studio Code que simule de forma gráfica y textual el funcionamiento de un procesador RISC-V con arquitecturas monociclo y segmentada, para facilitar la comprensión de los conceptos fundamentales de la asignatura Arquitectura de Computadores.

#### 4.2. Objetivos específicos

- Elaborar el documento de especificación de requisitos funcionales y no funcionales del simulador, detallando las características de visualización necesarias para las arquitecturas RISC-V monociclo y segmentada. Entregable: Documento de Especificación de Requisitos.
- 2. Diseñar la arquitectura de software de la extensión para Visual Studio Code y los prototipos de la interfaz de usuario (mockups), garantizando que la interacción sea intuitiva y responda a los requisitos definidos. **Entregable:** Documentos de diseño de arquitectura y prototipos/mockups de la interfaz.
- 3. Construir los módulos funcionales del simulador según el diseño establecido, implementando la carga de código, la ejecución paso a paso y la visualización en tiempo real de los componentes del procesador. **Entregable:** Código fuente de la extensión (versión funcional).
- 4. Ejecutar un plan de pruebas funcionales para verificar el correcto funcionamiento del simulador y realizar pruebas piloto con un grupo de usuarios (estudiantes y docentes) para evaluar la usabilidad y pertinencia pedagógica de la herramienta. Entregable: Informe de resultados de pruebas funcionales y de las pruebas piloto.

#### 5. Marco Referencial

#### 5.1. Marco Teórico

En este capítulo se definen los conceptos técnicos fundamentales que sustentan el desarrollo del proyecto. Se explican las tecnologías y arquitecturas clave necesarias para comprender tanto el problema abordado como la solución propuesta.

#### 5.1.1. Arquitectura RISC-V

RISC-V es una arquitectura de conjunto de instrucciones (ISA) basada en los principios de un computador con un conjunto reducido de instrucciones (RISC). A diferencia de otras arquitecturas comerciales, RISC-V es completamente gratuita y de código abierto, lo que

permite una amplia adopción y personalización ([8]). Su diseño es inherentemente modular, lo que significa que consiste en un conjunto base de instrucciones simples al que se le pueden añadir extensiones para funcionalidades específicas. Esta flexibilidad la hace ideal para una gran variedad de aplicaciones, desde pequeños sistemas embebidos hasta computadores de alto rendimiento ([6]).

#### 5.1.2. Procesador Segmentado (Pipelined)

Esta arquitectura mejora drásticamente el rendimiento al dividir la ejecución de una instrucción en múltiples etapas más cortas que operan en paralelo, de forma similar a una línea de ensamblaje. El modelo clásico para RISC-V se divide en cinco etapas: 1. Búsqueda (Fetch), 2. Decodificación (Decode), 3. Ejecución (Execute), 4. Memoria (Memory) y 5. Escritura (Write Back) ([4]). Al permitir que varias instrucciones se procesen simultáneamente en diferentes etapas, se logra un rendimiento mucho mayor que en el diseño monociclo. No obstante, esta paralelismo introduce complejidades como los riesgos" (hazards), que deben ser gestionados para asegurar el correcto funcionamiento ([3]).

#### 5.2. Estado del Arte

A continuación, se revisan otras herramientas de software que existen para enseñar arquitectura de computadores. Esto ayuda a entender por qué este proyecto es diferente y necesario. Herramientas como MARS (MIPS Assembler and Runtime Simulator), que es muy usada para enseñar la arquitectura MIPS, tienen una interfaz llena de información que puede confundir a un principiante ([10]). Igualmente, programas más nuevos para RISC-V como VRV o la página web WebRISC-V, son muy potentes, pero para usarlos bien, el estudiante ya necesita entender qué significa cada cosa que ve en la pantalla ([2], [5]).

#### Referencias

- [1] J Djordjevic, B Nikolic, B Tanja, and A Milenković. Cal2: Computer aided learning in computer architecture laboratory. *Computer Applications in Engineering Education*, 16(3):199–207, 2008.
- [2] R Giorgi and G Mariotti. WebriSC-V: A web-based education-oriented RISC-V pipeline simulation environment. In *Proceedings of the Workshop on Computer Architecture Education*, WCAE 2019, 2019.
- [3] R M Ihtemam, R Khan, and M A Qayum. Investigative analysis of three RISC-V microarchitectures in the context of computer architecture research. In 2024 27th International Conference on Computer and Information Technology, ICCIT 2024 - Proceedings, 2024.
- [4] S S Khairullah. Realization of a 16-bit MIPS RISC pipeline processor. In *HORA 2022 -* 4th International Congress on Human-Computer Interaction, Optimization and Robotic Applications, Proceedings, 2022.
- [5] S Krim and J Porquet-Lupine. VRV: A configurable and educational RISC-V simulator. In 2025 IEEE 18th International Symposium on Embedded Multicore/Many-core Systems-on-Chip (MCSoC), 2025.
- [6] J Mallidu and S V Siddamal. A survey on in-order 5-stage pipeline RISC-V processor implementation. Lecture Notes in Networks and Systems, 2023.
- [7] H Oztekin, F Temurtas, and A Gulbag. A software-based interactive system on BZK.SAU.FPGA10.1 micro computer design for teaching computer architecture and organization. In *ELECO 2011 7th International Conference on Electrical and Electronics Engineering*, 2011.
- [8] M S Poojary and H K Ravi. Design of RV32I instruction set architecture. In *International Conference on Smart Systems for Applications in Electrical Sciences, ICSSES 2025*, 2025.
- [9] N Senske. Confronting the challenges of computational design instruction. In Rethinking Comprehensive Design: Speculative Counterculture Proceedings of the 19th International Conference on Computer-Aided Architectural Design Research in Asia, CAADRIA 2014, 2014.
- [10] K Vollmar and P Sanderson. MARS: An education-oriented MIPS assembly language simulator. In *Proceedings of the Thirty-Seventh SIGCSE Technical Symposium on Computer Science Education*, 2007.