<?xml version="1.0" encoding="utf-8" standalone="yes"?><rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom" xmlns:content="http://purl.org/rss/1.0/modules/content/"><channel><title>Bare-Metal on Vamsi Kiran | Firmware Engineer</title><link>https://vamsikiran277.github.io/tags/bare-metal/</link><description>Recent content in Bare-Metal on Vamsi Kiran | Firmware Engineer</description><generator>Hugo</generator><language>en-us</language><lastBuildDate>Mon, 20 Apr 2026 10:00:00 +0000</lastBuildDate><atom:link href="https://vamsikiran277.github.io/tags/bare-metal/index.xml" rel="self" type="application/rss+xml"/><item><title>BSP-Backed Embedded Application</title><link>https://vamsikiran277.github.io/projects/bsp-application/</link><pubDate>Wed, 15 Apr 2026 10:00:00 +0000</pubDate><guid>https://vamsikiran277.github.io/projects/bsp-application/</guid><description>&lt;h3 id="-technology-stack"&gt;🛠 Technology Stack&lt;/h3&gt;
&lt;ul&gt;
&lt;li&gt;&lt;strong&gt;Languages:&lt;/strong&gt; Bare-Metal C (C11)&lt;/li&gt;
&lt;li&gt;&lt;strong&gt;Hardware:&lt;/strong&gt; STM32F407 (Discovery Board) - ARM Cortex-M4&lt;/li&gt;
&lt;li&gt;&lt;strong&gt;Simulation:&lt;/strong&gt; Renode (Antmicro)&lt;/li&gt;
&lt;li&gt;&lt;strong&gt;Protocols:&lt;/strong&gt; UART (USART2), SysTick Timer logic&lt;/li&gt;
&lt;li&gt;&lt;strong&gt;Tools:&lt;/strong&gt; arm-none-eabi-gcc, GDB, Renode&lt;/li&gt;
&lt;/ul&gt;
&lt;hr&gt;
&lt;h3 id="the-project-overview"&gt;The Project Overview&lt;/h3&gt;
&lt;p&gt;A modular firmware application demonstrating a clean separation between hardware-specific drivers (BSP) and high-level application logic. The project focuses on non-blocking execution, architectural maintainability, and full system virtualization using the Renode framework.&lt;/p&gt;
&lt;h3 id="technical-highlights"&gt;Technical Highlights&lt;/h3&gt;
&lt;ul&gt;
&lt;li&gt;&lt;strong&gt;Layered Architecture (BSP):&lt;/strong&gt; All register-level operations (RCC, GPIO, UART) are encapsulated within a dedicated Board Support Package. The application layer interacts only with abstract APIs, containing zero raw register addresses.&lt;/li&gt;
&lt;li&gt;&lt;strong&gt;Non-Blocking Logic:&lt;/strong&gt; Replaced &amp;ldquo;busy-wait&amp;rdquo; loops with a &lt;strong&gt;SysTick-based interrupt system&lt;/strong&gt;, allowing the CPU to process concurrent tasks (LED Heartbeat and Status Reporting) without stalling the execution thread.&lt;/li&gt;
&lt;li&gt;&lt;strong&gt;UART Serial Driver:&lt;/strong&gt; Developed a custom driver for USART2, featuring manual Baud Rate calculation for the &lt;strong&gt;16 MHz HSI clock&lt;/strong&gt; to ensure stable &lt;strong&gt;115200 baud&lt;/strong&gt; communication.&lt;/li&gt;
&lt;li&gt;&lt;strong&gt;Virtual Hardware Validation:&lt;/strong&gt; Successfully virtualized the STM32F407 hardware environment in &lt;strong&gt;Renode&lt;/strong&gt;, enabling cycle-accurate firmware testing and UART output auditing without physical silicon.&lt;/li&gt;
&lt;/ul&gt;
&lt;hr&gt;
&lt;h3 id="simulation--hardware-verification"&gt;Simulation &amp;amp; Hardware Verification&lt;/h3&gt;
&lt;p&gt;The project is validated using &lt;strong&gt;Renode&lt;/strong&gt; to audit register-level interactions and verify the timing logic of the Board Support Package. By mapping the internal &lt;code&gt;USART2&lt;/code&gt; peripheral to a virtual analyzer, the firmware execution is audited for cycle-accurate behavior before deployment to physical silicon.&lt;/p&gt;</description></item><item><title>Peripheral Driver Suite: GPIO, I2C, SPI &amp; UART</title><link>https://vamsikiran277.github.io/projects/peripheral-drivers/</link><pubDate>Mon, 20 Apr 2026 10:00:00 +0000</pubDate><guid>https://vamsikiran277.github.io/projects/peripheral-drivers/</guid><description>&lt;h3 id="-technology-stack"&gt;🛠 Technology Stack&lt;/h3&gt;
&lt;ul&gt;
&lt;li&gt;&lt;strong&gt;Languages:&lt;/strong&gt; C++ (OOP Approach), Makefile&lt;/li&gt;
&lt;li&gt;&lt;strong&gt;Protocols:&lt;/strong&gt; I2C, SPI, UART (Mini-UART), GPIO (Alternate Functions)&lt;/li&gt;
&lt;li&gt;&lt;strong&gt;Hardware:&lt;/strong&gt; Raspberry Pi 4 (BCM2711 / ARM Cortex-A72)&lt;/li&gt;
&lt;li&gt;&lt;strong&gt;Tools:&lt;/strong&gt; BCM2711 ARM Peripherals Datasheet, GCC Toolchain, GDB&lt;/li&gt;
&lt;/ul&gt;
&lt;hr&gt;
&lt;h3 id="the-project-overview"&gt;The Project Overview&lt;/h3&gt;
&lt;p&gt;Developed a comprehensive, register-level peripheral driver suite for the Raspberry Pi 4 using an Object-Oriented approach in C++. This project demonstrates how to translate complex technical datasheets into a modular, reusable Hardware Abstraction Layer (HAL).&lt;/p&gt;</description></item><item><title>ZX-8080 MCU: Bare-Metal Peripheral Control</title><link>https://vamsikiran277.github.io/projects/zx-8080-mcu/</link><pubDate>Sun, 12 Apr 2026 10:00:00 +0000</pubDate><guid>https://vamsikiran277.github.io/projects/zx-8080-mcu/</guid><description>&lt;h3 id="-technology-stack"&gt;🛠 Technology Stack&lt;/h3&gt;
&lt;ul&gt;
&lt;li&gt;&lt;strong&gt;Target Hardware:&lt;/strong&gt; ZX-8080 (32-bit RISC-V Architecture)&lt;/li&gt;
&lt;li&gt;&lt;strong&gt;Clock Speed:&lt;/strong&gt; 80 MHz System Frequency&lt;/li&gt;
&lt;li&gt;&lt;strong&gt;Language:&lt;/strong&gt; Bare-Metal C&lt;/li&gt;
&lt;li&gt;&lt;strong&gt;Toolchain:&lt;/strong&gt; RISC-V GCC (&lt;code&gt;riscv64-unknown-elf-gcc&lt;/code&gt;)&lt;/li&gt;
&lt;li&gt;&lt;strong&gt;Simulation:&lt;/strong&gt; Renode (Antmicro)&lt;/li&gt;
&lt;li&gt;&lt;strong&gt;Key Peripherals:&lt;/strong&gt; 12-bit SAR ADC, General Purpose Timer (TIM1), GPIO&lt;/li&gt;
&lt;/ul&gt;
&lt;hr&gt;
&lt;h3 id="the-project-overview"&gt;The Project Overview&lt;/h3&gt;
&lt;p&gt;This repository contains a bare-metal C implementation for the &lt;strong&gt;ZX-8080&lt;/strong&gt;, a custom 32-bit RISC-V based microcontroller. The project demonstrates low-level hardware abstraction by interfacing with an onboard 12-bit SAR ADC for thermal monitoring and utilizing a General Purpose Timer for precise LED toggling. Furthermore, the entire hardware environment is successfully virtualized and tested using the &lt;strong&gt;Renode&lt;/strong&gt; simulation framework.&lt;/p&gt;</description></item><item><title>STM32F4 Bare-Metal LED Toggle (Bit-Field &amp; SIL)</title><link>https://vamsikiran277.github.io/projects/bitfield-optimization/</link><pubDate>Sun, 12 Apr 2026 10:00:00 +0000</pubDate><guid>https://vamsikiran277.github.io/projects/bitfield-optimization/</guid><description>&lt;h3 id="-technology-stack"&gt;🛠 Technology Stack&lt;/h3&gt;
&lt;ul&gt;
&lt;li&gt;&lt;strong&gt;Language:&lt;/strong&gt; C (C11/C17)&lt;/li&gt;
&lt;li&gt;&lt;strong&gt;Hardware:&lt;/strong&gt; STM32F407 (ARM Cortex-M4)&lt;/li&gt;
&lt;li&gt;&lt;strong&gt;Tools:&lt;/strong&gt; Renode (SIL Simulation), STM32CubeIDE&lt;/li&gt;
&lt;li&gt;&lt;strong&gt;Key Concepts:&lt;/strong&gt; C Bit-Fields, MMIO, Software-in-the-Loop (SIL)&lt;/li&gt;
&lt;/ul&gt;
&lt;hr&gt;
&lt;h3 id="the-project-overview"&gt;The Project Overview&lt;/h3&gt;
&lt;p&gt;A low-level firmware implementation for the STM32F407 that demonstrates peripheral control via direct register manipulation. This project bypasses standard HAL/LL libraries to interface directly with the &lt;strong&gt;AHB1 bus matrix&lt;/strong&gt; using custom C bit-field structures for type-safe hardware access.&lt;/p&gt;
&lt;h3 id="technical-highlights"&gt;Technical Highlights&lt;/h3&gt;
&lt;ul&gt;
&lt;li&gt;&lt;strong&gt;C Bit-Field Structures:&lt;/strong&gt; Utilized custom &lt;code&gt;struct&lt;/code&gt; definitions to map hardware registers, ensuring type-safe access to individual bits and eliminating manual bitwise masks (&lt;code&gt;&amp;amp;&lt;/code&gt;, &lt;code&gt;|&lt;/code&gt;, &lt;code&gt;&amp;lt;&amp;lt;&lt;/code&gt;).&lt;/li&gt;
&lt;li&gt;&lt;strong&gt;Memory-Mapped I/O (MMIO):&lt;/strong&gt; Manually mapped the RCC (Base: &lt;code&gt;0x40023800&lt;/code&gt;) and GPIOD (Base: &lt;code&gt;0x40020C00&lt;/code&gt;) to control hardware clocking and pin states.&lt;/li&gt;
&lt;li&gt;&lt;strong&gt;SIL Validation (Renode):&lt;/strong&gt; Automated hardware verification using Renode to validate register-level behavior via memory-access tracing. This allows for cycle-accurate auditing of the firmware&amp;rsquo;s execution without physical hardware.&lt;/li&gt;
&lt;/ul&gt;
&lt;h3 id="-simulation--hardware-verification"&gt;🔍 Simulation &amp;amp; Hardware Verification&lt;/h3&gt;
&lt;p&gt;The project is validated using &lt;strong&gt;Renode&lt;/strong&gt; to trace memory-mapped I/O (MMIO) interactions. This ensures the firmware logic correctly targets the ARM Cortex-M4 register map before deployment to physical silicon.&lt;/p&gt;</description></item></channel></rss>