stm32中codedisk是什么作用

stm32中codedisk是什么作用,第1张

修饰存放在ROM中的变量。

code区是存放ROM代码的地方,这个存储分段是Cortex设定的, STM32只是遵循。

扫描隧道显微镜(Scanning Tunneling Microscope, 缩写为STM)是一种扫描探针显微术工具,扫描隧道显微镜可以空毕让科学家观察和定位单个原子,它具有比它的同类原子力显微镜更加高的分辨率。STM使人类第一次能够实时地观察单个原子在物质表面的排列状态和与表面电子行为有关的物化性质,在表面科学、材料科学、生命科学等领域的研究中有着重大的意义和广泛的应用前景,被国际科学界公认为20世纪107年代世界十大科技成就之一。隧道针尖的结构是扫描隧道显微技术要解决的主要问题之一。针尖的大小、形状和化学同一性不仅影响着扫描隧道显微镜图像的分辨率和图像的形状,而且也影响着测定的电子态。针尖的宏观结构应使得针尖具有高的弯曲共振频率,从而可以减少相位滞后,提高采集速度。如果针尖的尖端只有一唤亏手个稳定的原子而不是有多重针尖,那么隧道电流就会很稳定,而且能够获得原子级分辨的图像。针尖的化学纯度高,就不会涉及系列势垒。例如,针尖表面若有氧化层,则其电阻可能会高于隧道间隙的阻值,从而导致针尖和样品间产生隧道电和嫌流之前,二者就发生碰撞。制备针尖的材料主要有金属钨丝、铂-铱合金丝等。钨针尖的制备常用电化学腐蚀法。而铂- 铱合金针尖则多用机械成型法,一般 直接用剪刀剪切 而成。不论哪一种针尖,其表面往往覆盖着一层氧化层,或吸附一定的杂质,这经常是造成隧道电流不稳、噪音大和扫描隧道显微镜图象的不可预期性的原因。因此,每次实验前,都要对针尖进行处理,一般用化学法清洗,去除表面的氧化层及杂质,保证针尖具有良好的导电性。

stm32单片机可以用Keil5、STM32CubeIDE、IAR等进行编程。

1、Keil MDK:Keil支持目前大多数单片机,Keil根据不同内核单片机,分为几个版本,最常用的就物辩宽是Keil C51和MDK-ARM。像STC和一些51内核的单片机,一般用KeilC51版本,STM32则用的MDK-ARM。

2、STM32CubeIDE:STM32CubeIDE是ST公司推出的免费多功能STM32开发工具,可以说专门为STM32而生,新增了很多STM32专用功能,比如说外设图形化配置。为工程师大大提高开发效率,降低开发成本。

3、IAR:IAR我是在开发Ti蓝牙产品和基于STM8单片机会用到的。IAR也可以用来开发STM32的程序。通过IAR编译出来的程序比Keil优化得更好,最直接的体现就是编译出来的程序更节约内存空间。和上面Keil类似,IAR同样支持很多单片机,有很多功能基本两者都有。

STM32的介绍:

在STM32F105和STM32F107互连型系列微控制器之前,意法半导体已经推出STM32基本型系列、增强型系列、USB基本型系列、互补型系列;新系列产品沿用增强型系列的72MHz处理频率。

内存包括64KB到256KB闪存和20KB到64KB嵌入式SRAM。新系列采用LQFP64、LQFP100和LFBGA100三种封装,不同的封装保持引脚排列一致性,结合STM32平台的设计理念,开发人员通过选择产品可重新优化功能、存罩亮储器、性能和引脚数量,以最小的硬件变化来满足个性化的应用需求。

意法半导体(STMicroelectronics)整个集团共有员工近50000名,拥有16个先进的研发机构灶歼、39个设计和应用中心、15主要制造厂,并在36个国家设有78个销售办事处。

现在MDK在仿真试试,主要查看一下那些重要的寄存器有没有配置错误或者被其它代码档枣修改等。其实仿真没有问题,就应该怀疑你自己的板子问题。以下可以参考的代码:

/*******************普中科技 www.prechin.com**********************************

*

* STM32中断实验

*

* 实源清验目的行裂拆: 掌握中断的配置

* 连接方法: 用排线或杜邦线分别连 JP10--JP1 JP11--JP5

* 实验现象: 当K7按下LED灯 再按时,LED灯会熄灭

*

*******************************************************************************/

#include "stm32f10x_lib.h"

/******************************** 变量定义 ------------------------------------*/

EXTI_InitTypeDef EXTI_InitStructure

ErrorStatus HSEStartUpStatus

/*********************************声明函数 -----------------------------------------------*/

void RCC_Configuration(void)

void GPIO_Configuration(void)

void NVIC_Configuration(void)

/*******************************************************************************

*

*主函数

*

*******************************************************************************/

int main(void)

{

#ifdef DEBUG

debug()

#endif

RCC_Configuration() //系统时钟配置

NVIC_Configuration()//NVIC配置

GPIO_Configuration() //配置GPIO

///*将EXTI线6连接到PB6*/

GPIO_EXTILineConfig(GPIO_PortSourceGPIOB, GPIO_PinSource6)

/* Configure Key Button EXTI Line to generate an interrupt on falling edge */

//配置按钮中断线触发方式

EXTI_InitStructure.EXTI_Line = EXTI_Line6

EXTI_InitStructure.EXTI_Mode = EXTI_Mode_Interrupt

EXTI_InitStructure.EXTI_Trigger = EXTI_Trigger_Falling//下降沿触发

EXTI_InitStructure.EXTI_LineCmd = ENABLE//中断线使能

EXTI_Init(&EXTI_InitStructure)//初始化中断

/* Generate software interrupt: simulate a falling edge applied on Key Button EXTI line */

EXTI_GenerateSWInterrupt(EXTI_Line6)//EXTI_Line6中断允许 到此中断配置完成,可以写中断处理函数。

while (1)

{

}

}

/*******************************************************************************

*

*RCC配置

*

*******************************************************************************/

void RCC_Configuration(void)

{

//复位RCC外部设备寄存器到默认值

RCC_DeInit()

//打开外部高速晶振

RCC_HSEConfig(RCC_HSE_ON)

//等待外部高速时钟准备好

HSEStartUpStatus = RCC_WaitForHSEStartUp()

//外部高速时钟已经准别好

if(HSEStartUpStatus == SUCCESS)

{

FLASH_PrefetchBufferCmd(FLASH_PrefetchBuffer_Enable)

FLASH_SetLatency(FLASH_Latency_2)

//配置AHB(HCLK)时钟=SYSCLK

RCC_HCLKConfig(RCC_SYSCLK_Div1)

//配置APB2(PCLK2)钟=AHB时钟

RCC_PCLK2Config(RCC_HCLK_Div1)

//配置APB1(PCLK1)钟=AHB 1/2时钟

RCC_PCLK1Config(RCC_HCLK_Div2)

//配置ADC时钟=PCLK2 1/4

RCC_ADCCLKConfig(RCC_PCLK2_Div4)

//配置PLL时钟 == 外部高速晶体时钟*9

RCC_PLLConfig(RCC_PLLSource_HSE_Div1, RCC_PLLMul_9)

//配置ADC时钟= PCLK2/4

RCC_ADCCLKConfig(RCC_PCLK2_Div4)

//使能PLL时钟

RCC_PLLCmd(ENABLE)

//等待PLL时钟就绪

while(RCC_GetFlagStatus(RCC_FLAG_PLLRDY) == RESET)

{

}

//配置系统时钟 = PLL时钟

RCC_SYSCLKConfig(RCC_SYSCLKSource_PLLCLK)

//检查PLL时钟是否作为系统时钟

while(RCC_GetSYSCLKSource() != 0x08)

{

}

}

/* Enable Key Button GPIO Port, GPIO_LED and AFIO clock */

RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA |RCC_APB2Periph_GPIOB

| RCC_APB2Periph_AFIO, ENABLE)

}

/*************************************************

函数: void GPIO_Config(void)

功能: GPIO配置

**************************************************/

void GPIO_Configuration(void)

{

GPIO_InitTypeDef GPIO_InitStructure

GPIO_InitStructure.GPIO_Pin = GPIO_Pin_8

GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz

GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP //推挽输入

GPIO_Init(GPIOB, &GPIO_InitStructure)

GPIO_InitStructure.GPIO_Pin = GPIO_Pin_6

GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN_FLOATING //配置浮空输入

GPIO_Init(GPIOB, &GPIO_InitStructure)

}

/*******************************************************************************

* Function Name : NVIC_Configuration

* Description: Configure the nested vectored interrupt controller.

* Input : None

* Output : None

* Return : None

*******************************************************************************/

void NVIC_Configuration(void)

{

NVIC_InitTypeDef NVIC_InitStructure

#ifdef VECT_TAB_RAM

/* Set the Vector Table base location at 0x20000000 */

NVIC_SetVectorTable(NVIC_VectTab_RAM, 0x0) //分配中断向量表

#else /* VECT_TAB_FLASH */

/* Set the Vector Table base location at 0x08000000 */

NVIC_SetVectorTable(NVIC_VectTab_FLASH, 0x0)

#endif

/* Configure one bit for preemption priority */

NVIC_PriorityGroupConfig(NVIC_PriorityGroup_1) //设置中断优先级

/* Enable the EXTI9_5 Interrupt */

NVIC_InitStructure.NVIC_IRQChannel = EXTI9_5_IRQChannel//中断通道

NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 0 //强占优先级

NVIC_InitStructure.NVIC_IRQChannelSubPriority = 0//次优先级

NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE //通道中断使能

NVIC_Init(&NVIC_InitStructure)//初始化中断

}

#ifdef DEBUG

/*******************************************************************************

* Function Name : assert_failed

* Description: Reports the name of the source file and the source line number

* where the assert_param error has occurred.

* Input : - file: pointer to the source file name

* - line: assert_param error line source number

* Output : None

* Return : None

*******************************************************************************/

void assert_failed(u8* file, u32 line)

{

/* User can add his own implementation to report the file name and line number,

ex: printf("Wrong parameters value: file %s on line %d\r\n", file, line) */

/* Infinite loop */

while (1)

{

}

}

#endif

void EXTI9_5_IRQHandler(void)

{

if(EXTI_GetITStatus(EXTI_Line6) != RESET) //检测制定的EXTI线路触发请求是否发生。

{

/* Toggle GPIO_LED pin 7*/

GPIO_WriteBit(GPIOB, GPIO_Pin_8, (BitAction)((1-GPIO_ReadOutputDataBit(GPIOB, GPIO_Pin_8))))

/* Clear the Key Button EXTI line pending bit */

EXTI_ClearITPendingBit(EXTI_Line6)//清除EXTI线路挂起位

}

}

/******************* (C) COPYRIGHT 2008 STMicroelectronics *****END OF FILE****/


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/yw/12470357.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-25
下一篇 2023-05-25

发表评论

登录后才能评论

评论列表(0条)

保存