<?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>Embedded C on Vamsi Kiran | Firmware Engineer</title><link>https://vamsikiran277.github.io/tags/embedded-c/</link><description>Recent content in Embedded C on Vamsi Kiran | Firmware Engineer</description><generator>Hugo</generator><language>en-us</language><lastBuildDate>Sat, 18 Apr 2026 10:00:00 +0000</lastBuildDate><atom:link href="https://vamsikiran277.github.io/tags/embedded-c/index.xml" rel="self" type="application/rss+xml"/><item><title>FreeRTOS Task Management &amp; Sensor Suite</title><link>https://vamsikiran277.github.io/projects/freertos-tasks/</link><pubDate>Sat, 18 Apr 2026 10:00:00 +0000</pubDate><guid>https://vamsikiran277.github.io/projects/freertos-tasks/</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; Embedded C (C11)&lt;/li&gt;
&lt;li&gt;&lt;strong&gt;Operating System:&lt;/strong&gt; FreeRTOS (POSIX Port)&lt;/li&gt;
&lt;li&gt;&lt;strong&gt;Protocols:&lt;/strong&gt; I2C, Hardware Interrupts (GPIO)&lt;/li&gt;
&lt;li&gt;&lt;strong&gt;Tools:&lt;/strong&gt; libgpiod, GDB, GCC, Linux terminal&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;The objective was to design a robust, thread-safe sensor acquisition system on a Linux-based RTOS environment. This project demonstrates high-reliability multitasking where multiple sensors share a single communication bus without data corruption or timing jitter.&lt;/p&gt;
&lt;h3 id="technical-highlights"&gt;Technical Highlights&lt;/h3&gt;
&lt;ul&gt;
&lt;li&gt;&lt;strong&gt;Kernel-Level Multitasking:&lt;/strong&gt; Leveraged the &lt;strong&gt;FreeRTOS POSIX Port&lt;/strong&gt; to manage three concurrent tasks using fixed-priority preemption, ensuring mission-critical tasks always receive CPU time.&lt;/li&gt;
&lt;li&gt;&lt;strong&gt;Thread-Safe I2C Management:&lt;/strong&gt; Implemented a &lt;strong&gt;Mutex Semaphore&lt;/strong&gt; to arbitrate access to the I2C bus. This prevents data collisions between the &lt;strong&gt;ADXL345 Accelerometer&lt;/strong&gt; and &lt;strong&gt;DS3231 RTC&lt;/strong&gt; tasks when accessing shared hardware.&lt;/li&gt;
&lt;li&gt;&lt;strong&gt;Asynchronous Event Handling:&lt;/strong&gt; Developed a high-priority hardware listener using &lt;strong&gt;libgpiod&lt;/strong&gt; to capture falling-edge interrupts on GPIO 17, triggering a system-wide graceful shutdown.&lt;/li&gt;
&lt;li&gt;&lt;strong&gt;Deterministic Scheduling:&lt;/strong&gt; Replaced standard sleep calls with &lt;code&gt;vTaskDelayUntil()&lt;/code&gt; to ensure a consistent &lt;strong&gt;10Hz sampling frequency&lt;/strong&gt;, eliminating timing drift critical for real-time telemetry analysis.&lt;/li&gt;
&lt;li&gt;&lt;strong&gt;Resource Cleanup:&lt;/strong&gt; Engineered a custom &lt;code&gt;shutdown()&lt;/code&gt; sequence ensuring all RTOS tasks are deleted and Linux file descriptors (I2C/GPIO) are properly closed before process termination.&lt;/li&gt;
&lt;/ul&gt;
&lt;hr&gt;
&lt;h3 id="live-rtos-execution--task-arbitration"&gt;Live RTOS Execution &amp;amp; Task Arbitration&lt;/h3&gt;
&lt;p&gt;The following terminal trace captures the live execution of the FreeRTOS tasks. It demonstrates the real-time arbitration of the I2C bus between the high-frequency accelerometer and the low-frequency real-time clock.&lt;/p&gt;</description></item><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></channel></rss>