stm32f103c8t6 VGA显示的完整程序,加注释

时间: 2023-09-30 12:04:46 浏览: 52
以下是一份基于STM32F103C8T6单片机的VGA显示完整程序,包括必要的注释。请注意,该代码需要使用外部SRAM芯片才能工作。 ``` /* Includes */ #include "stm32f10x.h" #include "stm32f10x_gpio.h" #include "stm32f10x_rcc.h" /* Defines */ #define HSYNC_PIN GPIO_Pin_6 #define VSYNC_PIN GPIO_Pin_7 #define RED_PIN GPIO_Pin_0 #define GREEN_PIN GPIO_Pin_1 #define BLUE_PIN GPIO_Pin_2 /* Function prototypes */ void GPIO_Configuration(void); void FSMC_Configuration(void); void VGA_Init(void); void VGA_Draw_Pixel(uint16_t x, uint16_t y, uint8_t r, uint8_t g, uint8_t b); /* Global variables */ uint16_t frame_buffer[480][640] __attribute__((section(".sdram"))); /* Main function */ int main(void) { GPIO_Configuration(); FSMC_Configuration(); VGA_Init(); while (1) { /* Draw a red square */ for (int x = 100; x < 200; x++) { for (int y = 100; y < 200; y++) { VGA_Draw_Pixel(x, y, 255, 0, 0); } } } } /* Configure GPIO */ void GPIO_Configuration(void) { GPIO_InitTypeDef GPIO_InitStructure; /* Enable GPIOA and GPIOB clock */ RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA | RCC_APB2Periph_GPIOB, ENABLE); /* Configure HSYNC pin */ GPIO_InitStructure.GPIO_Pin = HSYNC_PIN; GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP; GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz; GPIO_Init(GPIOA, &GPIO_InitStructure); /* Configure VSYNC pin */ GPIO_InitStructure.GPIO_Pin = VSYNC_PIN; GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP; GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz; GPIO_Init(GPIOA, &GPIO_InitStructure); /* Configure RGB pins */ GPIO_InitStructure.GPIO_Pin = RED_PIN | GREEN_PIN | BLUE_PIN; GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP; GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz; GPIO_Init(GPIOB, &GPIO_InitStructure); } /* Configure FSMC */ void FSMC_Configuration(void) { FSMC_NORSRAMInitTypeDef FSMC_NORSRAMInitStructure; FSMC_NORSRAMTimingInitTypeDef FSMC_NORSRAMTimingInitStructure; /* Enable FSMC clock */ RCC_AHBPeriphClockCmd(RCC_AHBPeriph_FSMC, ENABLE); /* Configure FSMC timing */ FSMC_NORSRAMTimingInitStructure.FSMC_AddressSetupTime = 0; FSMC_NORSRAMTimingInitStructure.FSMC_AddressHoldTime = 0; FSMC_NORSRAMTimingInitStructure.FSMC_DataSetupTime = 7; FSMC_NORSRAMTimingInitStructure.FSMC_BusTurnAroundDuration = 0; FSMC_NORSRAMTimingInitStructure.FSMC_CLKDivision = 0; FSMC_NORSRAMTimingInitStructure.FSMC_DataLatency = 0; FSMC_NORSRAMTimingInitStructure.FSMC_AccessMode = FSMC_AccessMode_B; /* Configure FSMC NOR/SRAM bank */ FSMC_NORSRAMInitStructure.FSMC_Bank = FSMC_Bank1_NORSRAM1; FSMC_NORSRAMInitStructure.FSMC_DataAddressMux = FSMC_DataAddressMux_Disable; FSMC_NORSRAMInitStructure.FSMC_MemoryType = FSMC_MemoryType_SRAM; FSMC_NORSRAMInitStructure.FSMC_MemoryDataWidth = FSMC_MemoryDataWidth_16b; FSMC_NORSRAMInitStructure.FSMC_BurstAccessMode = FSMC_BurstAccessMode_Disable; FSMC_NORSRAMInitStructure.FSMC_AsynchronousWait = FSMC_AsynchronousWait_Disable; FSMC_NORSRAMInitStructure.FSMC_WaitSignalPolarity = FSMC_WaitSignalPolarity_Low; FSMC_NORSRAMInitStructure.FSMC_WrapMode = FSMC_WrapMode_Disable; FSMC_NORSRAMInitStructure.FSMC_WaitSignalActive = FSMC_WaitSignalActive_BeforeWaitState; FSMC_NORSRAMInitStructure.FSMC_WriteOperation = FSMC_WriteOperation_Enable; FSMC_NORSRAMInitStructure.FSMC_WaitSignal = FSMC_WaitSignal_Disable; FSMC_NORSRAMInitStructure.FSMC_ExtendedMode = FSMC_ExtendedMode_Disable; FSMC_NORSRAMInitStructure.FSMC_WriteBurst = FSMC_WriteBurst_Disable; FSMC_NORSRAMInitStructure.FSMC_ReadWriteTimingStruct = &FSMC_NORSRAMTimingInitStructure; FSMC_NORSRAMInitStructure.FSMC_WriteTimingStruct = &FSMC_NORSRAMTimingInitStructure; /* Initialize FSMC */ FSMC_NORSRAMInit(&FSMC_NORSRAMInitStructure); /* Enable FSMC bank */ FSMC_NORSRAMCmd(FSMC_Bank1_NORSRAM1, ENABLE); } /* Initialize VGA */ void VGA_Init(void) { /* Configure HSYNC pin */ GPIO_SetBits(GPIOA, HSYNC_PIN); /* Configure VSYNC pin */ GPIO_SetBits(GPIOA, VSYNC_PIN); /* Wait for VSYNC */ while ((GPIOA->IDR & VSYNC_PIN) == 0); /* Wait for VSYNC to end */ while ((GPIOA->IDR & VSYNC_PIN) != 0); } /* Draw a pixel on the screen */ void VGA_Draw_Pixel(uint16_t x, uint16_t y, uint8_t r, uint8_t g, uint8_t b) { /* Save RGB values to the frame buffer */ frame_buffer[y][x] = (r << 11) | (g << 5) | b; } /* Set up the SDRAM controller */ void SystemInit_ExtMemCtl(void) { /* Enable GPIOC, GPIOD, GPIOE, GPIOF and GPIOG interface clock */ RCC_AHBPeriphClockCmd(RCC_AHBPeriph_GPIOC | RCC_AHBPeriph_GPIOD | RCC_AHBPeriph_GPIOE | RCC_AHBPeriph_GPIOF | RCC_AHBPeriph_GPIOG, ENABLE); /* Connect PCx, PDx, PEx, PFx and PGx pins to SDRAM module */ GPIO_PinAFConfig(GPIOC, GPIO_PinSource0, GPIO_AF_FSMC); GPIO_PinAFConfig(GPIOC, GPIO_PinSource2, GPIO_AF_FSMC); GPIO_PinAFConfig(GPIOC, GPIO_PinSource3, GPIO_AF_FSMC); GPIO_PinAFConfig(GPIOC, GPIO_PinSource4, GPIO_AF_FSMC); GPIO_PinAFConfig(GPIOC, GPIO_PinSource5, GPIO_AF_FSMC); GPIO_PinAFConfig(GPIOC, GPIO_PinSource6, GPIO_AF_FSMC); GPIO_PinAFConfig(GPIOC, GPIO_PinSource7, GPIO_AF_FSMC); GPIO_PinAFConfig(GPIOC, GPIO_PinSource8, GPIO_AF_FSMC); GPIO_PinAFConfig(GPIOC, GPIO_PinSource9, GPIO_AF_FSMC); GPIO_PinAFConfig(GPIOC, GPIO_PinSource10, GPIO_AF_FSMC); GPIO_PinAFConfig(GPIOC, GPIO_PinSource11, GPIO_AF_FSMC); GPIO_PinAFConfig(GPIOC, GPIO_PinSource12, GPIO_AF_FSMC); GPIO_PinAFConfig(GPIOC, GPIO_PinSource13, GPIO_AF_FSMC); GPIO_PinAFConfig(GPIOC, GPIO_PinSource14, GPIO_AF_FSMC); GPIO_PinAFConfig(GPIOC, GPIO_PinSource15, GPIO_AF_FSMC); GPIO_PinAFConfig(GPIOD, GPIO_PinSource0, GPIO_AF_FSMC); GPIO_PinAFConfig(GPIOD, GPIO_PinSource1, GPIO_AF_FSMC); GPIO_PinAFConfig(GPIOD, GPIO_PinSource3, GPIO_AF_FSMC); GPIO_PinAFConfig(GPIOD, GPIO_PinSource4, GPIO_AF_FSMC); GPIO_PinAFConfig(GPIOD, GPIO_PinSource5, GPIO_AF_FSMC); GPIO_PinAFConfig(GPIOD, GPIO_PinSource6, GPIO_AF_FSMC); GPIO_PinAFConfig(GPIOD, GPIO_PinSource7, GPIO_AF_FSMC); GPIO_PinAFConfig(GPIOD, GPIO_PinSource8, GPIO_AF_FSMC); GPIO_PinAFConfig(GPIOD, GPIO_PinSource9, GPIO_AF_FSMC); GPIO_PinAFConfig(GPIOD, GPIO_PinSource10, GPIO_AF_FSMC); GPIO_PinAFConfig(GPIOD, GPIO_PinSource11, GPIO_AF_FSMC); GPIO_PinAFConfig(GPIOD, GPIO_PinSource12, GPIO_AF_FSMC); GPIO_PinAFConfig(GPIOD, GPIO_PinSource13, GPIO_AF_FSMC); GPIO_PinAFConfig(GPIOD, GPIO_PinSource14, GPIO_AF_FSMC); GPIO_PinAFConfig(GPIOD, GPIO_PinSource15, GPIO_AF_FSMC); GPIO_PinAFConfig(GPIOE, GPIO_PinSource0, GPIO_AF_FSMC); GPIO_PinAFConfig(GPIOE, GPIO_PinSource1, GPIO_AF_FSMC); GPIO_PinAFConfig(GPIOE, GPIO_PinSource3, GPIO_AF_FSMC); GPIO_PinAFConfig(GPIOE, GPIO_PinSource4, GPIO_AF_FSMC); GPIO_PinAFConfig(GPIOE, GPIO_PinSource5, GPIO_AF_FSMC); GPIO_PinAFConfig(GPIOE, GPIO_PinSource6, GPIO_AF_FSMC); GPIO_PinAFConfig(GPIOE, GPIO_PinSource7, GPIO_AF_FSMC); GPIO_PinAFConfig(GPIOE, GPIO_PinSource8, GPIO_AF_FSMC); GPIO_PinAFConfig(GPIOE, GPIO_PinSource9, GPIO_AF_FSMC); GPIO_PinAFConfig(GPIOE, GPIO_PinSource10, GPIO_AF_FSMC); GPIO_PinAFConfig(GPIOE, GPIO_PinSource11, GPIO_AF_FSMC); GPIO_PinAFConfig(GPIOE, GPIO_PinSource12, GPIO_AF_FSMC); GPIO_PinAFConfig(GPIOE, GPIO_PinSource13, GPIO_AF_FSMC); GPIO_PinAFConfig(GPIOE, GPIO_PinSource14, GPIO_AF_FSMC); GPIO_PinAFConfig(GPIOE, GPIO_PinSource15, GPIO_AF_FSMC); GPIO_PinAFConfig(GPIOF, GPIO_PinSource0, GPIO_AF_FSMC); GPIO_PinAFConfig(GPIOF, GPIO_PinSource1, GPIO_AF_FSMC); GPIO_PinAFConfig(GPIOF, GPIO_PinSource2, GPIO_AF_FSMC); GPIO_PinAFConfig(GPIOF, GPIO_PinSource3, GPIO_AF_FSMC); GPIO_PinAFConfig(GPIOF, GPIO_PinSource4, GPIO_AF_FSMC); GPIO_PinAFConfig(GPIOF, GPIO_PinSource5, GPIO_AF_FSMC); GPIO_PinAFConfig(GPIOF, GPIO_PinSource12, GPIO_AF_FSMC); GPIO_PinAFConfig(GPIOF, GPIO_PinSource13, GPIO_AF_FSMC); GPIO_PinAFConfig(GPIOF, GPIO_PinSource14, GPIO_AF_FSMC); GPIO_PinAFConfig(GPIOF, GPIO_PinSource15, GPIO_AF_FSMC); GPIO_PinAFConfig(GPIOG, GPIO_PinSource0, GPIO_AF_FSMC); GPIO_PinAFConfig(GPIOG, GPIO_PinSource1, GPIO_AF_FSMC); GPIO_PinAFConfig(GPIOG, GPIO_PinSource2, GPIO_AF_FSMC); GPIO_PinAFConfig(GPIOG, GPIO_PinSource3, GPIO_AF_FSMC); GPIO_PinAFConfig(GPIOG, GPIO_PinSource4, GPIO_AF_FSMC); GPIO_PinAFConfig(GPIOG, GPIO_PinSource5, GPIO_AF_FSMC); GPIO_PinAFConfig(GPIOG, GPIO_PinSource10, GPIO_AF_FSMC); /* Enable FSMC clock */ RCC_AHBPeriphClockCmd(RCC_AHBPeriph_FSMC, ENABLE); /* FSMC configuration */ FSMC_NORSRAMInitTypeDef FSMC_NORSRAMInitStructure; FSMC_NORSRAMTimingInitTypeDef FSMC_NORSRAMTimingInitStructure; FSMC_NORSRAMTimingInitStructure.FSMC_AddressSetupTime = 0x02; FSMC_NORSRAMTimingInitStructure.FSMC_AddressHoldTime = 0x00; FSMC_NORSRAMTimingInitStructure.FSMC_DataSetupTime = 0x05; FSMC_NORSRAMTimingInitStructure.FSMC_BusTurnAroundDuration = 0x00; FSMC_NORSRAMTimingInitStructure.FSMC_CLKDivision = 0x00; FSMC_NORSRAMTimingInitStructure.FSMC_DataLatency = 0x00; FSMC_NORSRAMTimingInitStructure.FSMC_AccessMode = FSMC_AccessMode_A; FSMC_NORSRAMInitStructure.FSMC_Bank = FSMC_Bank1_NORSRAM1; FSMC_NORSRAMInitStructure.FSMC_DataAddressMux = FSMC_DataAddressMux_Enable; FSMC_NORSRAMInitStructure.FSMC_MemoryType = FSMC_MemoryType_SRAM; FSMC_NORSRAMInitStructure.FSMC_MemoryDataWidth = FSMC_MemoryDataWidth_16b; FSMC_NORSRAMInitStructure.FSMC_BurstAccessMode = FSMC_BurstAccessMode_Disable; FSMC_NORSRAMInitStructure.FSMC_AsynchronousWait = FSMC_AsynchronousWait_Disable; FSMC_NORSRAMInitStructure.FSMC_WaitSignalPolarity = FSMC_WaitSignalPolarity_Low; FSMC_NORSRAMInitStructure.FSMC_WrapMode = FSMC_WrapMode_Disable; FSMC_NORSRAMInitStructure.FSMC_WaitSignalActive = FSMC_WaitSignalActive_BeforeWaitState; FSMC_NORSRAMInitStructure.FSMC_WriteOperation = FSMC_WriteOperation_Enable; FSMC_NORSRAMInitStructure.FSMC_WaitSignal = FSMC_WaitSignal_Disable; FSMC_NORSRAMInitStructure.FSMC_ExtendedMode = FSMC_ExtendedMode_Disable; FSMC_NORSRAMInitStructure.FSMC_WriteBurst = FSMC_WriteBurst_Disable; FSMC_NORSRAMInitStructure.FSMC_ReadWriteTimingStruct = &FSMC_NORSRAMTimingInitStructure; FSMC_NORSRAMInitStructure.FSMC_WriteTimingStruct = &FSMC_NORSRAMTimingInitStructure; /* Initialize FSMC */ FSMC_NORSRAMInit(&FSMC_NORSRAMInitStructure); /* Enable FSMC bank */ FSMC_NORSRAMCmd(FSMC_Bank1_NORSRAM1, ENABLE); } ``` 需要注意的一些点: - 该代码使用了外部SDRAM芯片来存储像素数据,因此需要在系统初始化时调用SystemInit_ExtMemCtl函数以对SDRAM进行初始化。 - VGA_Draw_Pixel函数将RGB值存储到帧缓冲区中,帧缓冲区是一个二维数组,每个元素代表一个像素。 - 该程序仅绘制了一个红色正方形,可以根据需要修改以绘制不同的图形。

相关推荐

最新推荐

recommend-type

STM32F103C8T6开发板+GY521制作Betaflight飞控板详细图文教程

STM32F103C8T6黑色开发板1个(11.5元) GY-521加速度计模块1个(3.8元) ams1117-3.3电压转换芯片1个(0.38元) 5V有源蜂鸣器1个(0.43元) 5cm*7cm洞洞板1个(0.45元)  肖特基二极管2个 ss8050三极管2个 1k电阻2个,...
recommend-type

MAX30102心率血氧传感器在STM32F103C8T6上的应用

标准库与HAL库,用IO口模拟IIC void I2C_GPIO_Config(void) //IIC引脚初始化 { #ifdef STDLIB GPIO_InitTypeDef GPIO_InitStructure; RCC_APB2PeriphClockCmd&#40;RCC_APB2Periph_GPIOB , ENABLE&#41;...
recommend-type

【MCU实战经验】基于STM32F103C8T6的hart总线收发器设计

HART总线调试器是基于HART...使用本设备可以对现场终端的测量范围、阻尼时间、显示模式等参数变量进行现场设定和调校,并能对终端设备进行现场不断电测试和诊断。这在很多时间对现场生产设备的可靠安全运行很有意义。
recommend-type

启明欣欣stm32f103rct6开发板原理图

启明欣欣stm32f103rct6开发板原理图 哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈...
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

实现实时数据湖架构:Kafka与Hive集成

![实现实时数据湖架构:Kafka与Hive集成](https://img-blog.csdnimg.cn/img_convert/10eb2e6972b3b6086286fc64c0b3ee41.jpeg) # 1. 实时数据湖架构概述** 实时数据湖是一种现代数据管理架构,它允许企业以低延迟的方式收集、存储和处理大量数据。与传统数据仓库不同,实时数据湖不依赖于预先定义的模式,而是采用灵活的架构,可以处理各种数据类型和格式。这种架构为企业提供了以下优势: - **实时洞察:**实时数据湖允许企业访问最新的数据,从而做出更明智的决策。 - **数据民主化:**实时数据湖使各种利益相关者都可
recommend-type

用matlab绘制高斯色噪声情况下的频率估计CRLB,其中w(n)是零均值高斯色噪声,w(n)=0.8*w(n-1)+e(n),e(n)服从零均值方差为se的高斯分布

以下是用matlab绘制高斯色噪声情况下频率估计CRLB的代码: ```matlab % 参数设置 N = 100; % 信号长度 se = 0.5; % 噪声方差 w = zeros(N,1); % 高斯色噪声 w(1) = randn(1)*sqrt(se); for n = 2:N w(n) = 0.8*w(n-1) + randn(1)*sqrt(se); end % 计算频率估计CRLB fs = 1; % 采样频率 df = 0.01; % 频率分辨率 f = 0:df:fs/2; % 频率范围 M = length(f); CRLB = zeros(M,1); for
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。
recommend-type

"互动学习:行动中的多样性与论文攻读经历"

多样性她- 事实上SCI NCES你的时间表ECOLEDO C Tora SC和NCESPOUR l’Ingén学习互动,互动学习以行动为中心的强化学习学会互动,互动学习,以行动为中心的强化学习计算机科学博士论文于2021年9月28日在Villeneuve d'Asq公开支持马修·瑟林评审团主席法布里斯·勒菲弗尔阿维尼翁大学教授论文指导奥利维尔·皮耶昆谷歌研究教授:智囊团论文联合主任菲利普·普雷教授,大学。里尔/CRISTAL/因里亚报告员奥利维耶·西格德索邦大学报告员卢多维奇·德诺耶教授,Facebook /索邦大学审查员越南圣迈IMT Atlantic高级讲师邀请弗洛里安·斯特鲁布博士,Deepmind对于那些及时看到自己错误的人...3谢谢你首先,我要感谢我的两位博士生导师Olivier和Philippe。奥利维尔,"站在巨人的肩膀上"这句话对你来说完全有意义了。从科学上讲,你知道在这篇论文的(许多)错误中,你是我可以依