ARM常用函数的配置函数---重点积累

发布者:和谐相伴最新更新时间:2015-10-19 来源: eefocus关键字:ARM  常用函数  配置函数  重点积累 手机看文章 扫描二维码
随时随地手机看文章
//Author:"泪与汗的缠绵"

//Data:2011-11月

//功能:积累编程的思想与套路

本页所包含的配置函数有:
void SysTick_Configuration(void);
void GPIO_Configuration(void); //端口引脚功能的配置
void EXTI_Configuration(void);//配置外部中断线
void NVIC_Configuration(void); //配置中断的优先级、内部中断向量
void RCC_Configuration(void); //配置系统及其外设的时钟
void IWDG_Configuration(void);//看门狗的配置结构
void  TIM_Configuration(void)
void  ADC_configuration();
void DMA_Configuration(void);
void DAC_Configuration(void);
//同时需要配置的结构体变量
GPIO_InitTypeDef GPIO_InitStructure;
EXTI_InitTypeDef EXTI_InitStructure;
NVIC_InitTypeDef NVIC_InitStructure;

*******//Cortex系统定时器(SysTick)*********************
*******************************************************
*******************************************************
void SysTick_Configuration(void)
{
    
   //选择系统定时器(SysTick)的时钟源
    SysTick_CLKSourceConfig(SysTick_CLKSource_HCLK_Div8);

  
   SysTick_SetReload(250000);

   
  SysTick_CounterCmd(SysTick_Counter_Enable);

 
   SysTick_ITConfig(ENABLE);
}
*********///GPIO的配置程序***************************************
******************************************************************
*******************************************************************
void GPIO_Configuration(void) void RCC_Configuration(void)
{
  GPIO_InitTypeDef GPIO_InitStructure;
 
 
  GPIO_InitStructure.GPIO_Pin = GPIO_Pin_6|GPIO_Pin_7|GPIO_Pin_8|GPIO_Pin_9;
  GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
  GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP;
  GPIO_Init(GPIOC, &GPIO_InitStructure);
   
 
  GPIO_InitStructure.GPIO_Pin = GPIO_Pin_9;
  GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN_FLOATING;
  GPIO_Init(GPIOB, &GPIO_InitStructure);
}
//中断线路初始化
void EXTI_Configuration(void)
{
   
  EXTI_InitStructure.EXTI_Line = EXTI_Line9;
  EXTI_InitStructure.EXTI_Mode = EXTI_Mode_Interrupt;
  EXTI_InitStructure.EXTI_Trigger = EXTI_Trigger_Falling;
  EXTI_InitStructure.EXTI_LineCmd = ENABLE;
  EXTI_Init(&EXTI_InitStructure);

   
  EXTI_InitStructure.EXTI_Line = EXTI_Line13;
  EXTI_InitStructure.EXTI_Mode = EXTI_Mode_Interrupt;
  EXTI_InitStructure.EXTI_Trigger = EXTI_Trigger_Falling;
  EXTI_InitStructure.EXTI_LineCmd = ENABLE;
  EXTI_Init(&EXTI_InitStructure);
}
///嵌套中断向量NVIC**********************************
/
    GPIO_EXTILineConfig(GPIO_PortSourceGPIOB, GPIO_PinSource9);
 NVIC_PriorityGroupConfig(NVIC_PriorityGroup_1);
 NVIC_InitStructure.NVIC_IRQChannel=EXTI0_IRQChannel;
 NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority=0;
 NVIC_InitStructure.NVIC_IRQChannelSubPriority=0;
 NVIC_InitStructure.NVIC_IRQChannelCmd=ENABLE;
 NVIC_Init(&NVIC_InitStructure);

 //为EXTI_Line9使能并配置中断向量
 
    //为EXTI_Line0使能并配置中断向量
 GPIO_EXTILineConfig(GPIO_PortSourceGPIOB, GPIO_PinSource9);
 NVIC_InitStructure.NVIC_IRQChannel=EXTI9_5_IRQChannel;
 NVIC_Init(&NVIC_InitStructure);

 //为EXTI_Line9使能并配置中断向量
 
 //为EXTI_Line13使能并配置中断向量
 GPIO_EXTILineConfig(GPIO_PortSourceGPIOB, GPIO_PinSource9);
 NVIC_InitStructure.NVIC_IRQChannel=EXTI15_10_IRQChannel;
 NVIC_Init(&NVIC_InitStructure);

}

********************************************************************
**************系统时钟的配置RCC_Configuration**********************
void RCC_Configuration(void)
{
 
  RCC_DeInit();
  
  RCC_HSEConfig(RCC_HSE_ON);
   
  HSEStartUpStatus = RCC_WaitForHSEStartUp();
    if(HSEStartUpStatus == SUCCESS)
  {
   
    RCC_HCLKConfig(RCC_SYSCLK_Div1);
      
    RCC_PCLK2Config(RCC_HCLK_Div1);
      
    RCC_PCLK1Config(RCC_HCLK_Div2);
      
    FLASH_SetLatency(FLASH_Latency_2);
   
    FLASH_PrefetchBufferCmd(FLASH_PrefetchBuffer_Enable);
  */
    RCC_PLLConfig(RCC_PLLSource_HSE_Div1, RCC_PLLMul_9);
     
    RCC_PLLCmd(ENABLE);
     
    while(RCC_GetFlagStatus(RCC_FLAG_PLLRDY) == RESET)
    {
    }
    
    RCC_SYSCLKConfig(RCC_SYSCLKSource_PLLCLK);
      
    while(RCC_GetSYSCLKSource() != 0x08)
    {
    }
 
  RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOC | RCC_APB2Periph_GPIOB |RCC_APB2Periph_AFIO, ENABLE); 

  
  RCC_APB1PeriphClockCmd(RCC_APB1Periph_PWR | RCC_APB1Periph_BKP, ENABLE);

  }[page]
*****************//初始化独立看门狗******************************
********************************************************************
********************************************************************
********************************************************************
void IWDG_Configuration(void)
{
 
 
  //是能或者失能对寄存器IWDG_PR和IWDG_RLR
  IWDG_WriteAccessCmd(IWDG_WriteAccess_Enable);

 
  //选定工作频率
  IWDG_SetPrescaler(IWDG_Prescaler_32);

  //设置重装载值
  IWDG_SetReload(230);

 
  //按照重装载器的值重装载IWDG计数器的值-----------此动作相当于“喂狗”
  IWDG_ReloadCounter();

 
  //使能IWDG
  IWDG_Enable();
}
/ *******************
/
   TIM_DeInit(TIM1); //将外设TIMx寄存器重设为缺省值
//2、基础设置
 
  TIM1_TimeBaseStructure.TIM_Prescaler = 0x0; //预分频,此值+1为分频的除数得到计数周期;
  TIM1_TimeBaseStructure.TIM_Period = 0xFFFF;//计数周期 (即当计数值达到“计数值”时,刚好用时一个计数周期) 
  TIM1_TimeBaseStructure.TIM_ClockDivision = 0x0;//时钟因子
  TIM1_TimeBaseStructure.TIM_RepetitionCounter = 0x0;
  TIM1_TimeBaseStructure.TIM_CounterMode = TIM_CounterMode_Up; //计数器模式
             //TIM_CounterMode_Dowm            向下计数
             //TIM_CounterMode_CenterAligned1 中心对齐方式1
            // TIM_CounterMode_CenterAligned2 中心对齐方式2
            // TIM_CounterMode_CenterAligned3 中心对齐方式3

  TIM_TimeBaseInit(TIM1,&TIM1_TimeBaseStructure);
// 3、输出通道设置
 
  TIM1_OCInitStructure.TIM_OCMode = TIM_OCMode_PWM2;
  //TIM_OCMode_Timing输出比较时间模式(输出引脚冻结无效)
  //TIM_OCMode_Active 输出比较主动模式(匹配时设置输出引脚为有效电平,当计数值为比较/捕获寄存器值相同时,强制输出为高平)                            
  TIM_OCMode_Inactive; 输出比较非主动模式 (匹配时设置输出引脚为无效电平,当计数值为比较/捕获寄存器值相同时,强制输出为低电平)     
  //TIM_OCMode_Toggle 输出比较触发模式(翻转。当计数值与比较/捕获寄存器值相同时,翻转输出引脚的电平)
  //TIM_OCMode_PWM1向上计数时,当TIMx_CNT < TIMx_CCR*时,输出电平有效,否则为无效,
  //向下计数时,当TIMx_CNT > TIMx_CCR*时,输出电平无效,否则为有效  
  //TIM_OCMode_PWM2 ;与PWM1模式相反

  TIM1_OCInitStructure.TIM_OutputState = TIM_OutputState_Enable;
  TIM1_OCInitStructure.TIM_OutputNState = TIM_OutputNState_Enable;                 
  TIM1_OCInitStructure.TIM_Pulse = CCR1_Val;
  TIM1_OCInitStructure.TIM_OCPolarity = TIM_OCPolarity_Low;
  TIM1_OCInitStructure.TIM_OCNPolarity = TIM_OCNPolarity_Low;        
  TIM1_OCInitStructure.TIM_OCIdleState = TIM_OCIdleState_Set;
  TIM1_OCInitStructure.TIM_OCNIdleState = TIM_OCIdleState_Reset;         
 
  TIM_OC1Init(TIM1,&TIM1_OCInitStructure);

  TIM1_OCInitStructure.TIM_Pulse = CCR2_Val;
  TIM_OC2Init(TIM1,&TIM1_OCInitStructure);

  TIM1_OCInitStructure.TIM_Pulse = CCR3_Val;
  TIM_OC3Init(TIM1,&TIM1_OCInitStructure);

 
  TIM1_BDTRInitStructure.TIM_OSSRState = TIM_OSSRState_Enable;
  TIM1_BDTRInitStructure.TIM_OSSIState = TIM_OSSIState_Enable;
  TIM1_BDTRInitStructure.TIM_LOCKLevel = TIM_LOCKLevel_1;
  TIM1_BDTRInitStructure.TIM_DeadTime = 0x75;
  TIM1_BDTRInitStructure.TIM_Break = TIM_Break_Enable;
  TIM1_BDTRInitStructure.TIM_BreakPolarity = TIM_BreakPolarity_High;
  TIM1_BDTRInitStructure.TIM_AutomaticOutput = TIM_AutomaticOutput_Enable;

  TIM_BDTRConfig(TIM1,&TIM1_BDTRInitStructure);

 
  TIM_Cmd(TIM1,ENABLE);

 
  TIM_CtrlPWMOutputs(TIM1,ENABLE);
  }

  ////////////AD的配置函数/////////////////////////////
   
 //时钟配置:
 // ADCCLK = PCLK2/4
   
 //应用配置
void  ADC_configuration()
{
  ADC_InitTypeDef  ADC_InitStructure;
  ADC_InitStructure.ADC_Mode = ADC_Mode_Independent;
   
  ADC_InitStructure.ADC_ScanConvMode = ENABLE;
         //ADC_ScanConvMode 规定了模数转换工作在扫描模式(多通道)还是单次(单通道)模式。可以设置这个
         //问ENABLE 或者 DISABLE。                                       
  ADC_InitStructure.ADC_ContinuousConvMode=ENABLE;     
         //ADC_ContinuousConvMode 规定了模数转换工作在连续还是单次模式。可以设置这个参数为 ENABLE 或
         //DISABLE。
  ADC_InitStructure.ADC_ExternalTrigConv = ADC_ExternalTrigConv_None;
      //ADC_ExternalTrigConv  描述
      //ADC_ExternalTrigConv_T1_CC1  选择定时器 1 的捕获比较 1 作为转换外部触发
      //ADC_ExternalTrigConv_T1_CC2  选择定时器 1 的捕获比较 2 作为转换外部触发
      //ADC_ExternalTrigConv_T1_CC3  选择定时器 1 的捕获比较 3 作为转换外部触发
      //ADC_ExternalTrigConv_T2_CC2  选择定时器 2 的捕获比较 2 作为转换外部触发
      //ADC_ExternalTrigConv_T3_TRGO  选择定时器 3 的 TRGO作为转换外部触发
      //ADC_ExternalTrigConv_T4_CC4  选择定时器 4 的捕获比较 4 作为转换外部触发
      //ADC_ExternalTrigConv_Ext_IT11  选择外部中断线 11 事件作为转换外部触发
      //ADC_ExternalTrigConv_None  转换由软件而不是外部触Ⅳ?
  ADC_InitStructure.ADC_DataAlign=ADC_DataAlign_Right;
      //ADC_DataAlign  描述:
      //ADC_DataAlign_Right  ADC 数据右对齐
      //ADC_DataAlign_Left  ADC 数据左对齐
  ADC_InitStructure.ADC_NbrOfChannel = 1; // 规定了顺序进行规则转换的 ADC 通道的数目。这个数目的取值范围是 1 到16。
       //ADC_NbreOfChannel
  ADC_Init(ADC1, &ADC_InitStructure);
 
 
  ADC_RegularChannelConfig(ADC1, ADC_Channel_14, 1, ADC_SampleTime_55Cycles5);
      //(ADC1 或 ADC2,ADC_Channel_X,Rank,ADC_SampleTime);
                                   //规则组采样顺序。取值范围 1 到16。  
  // ADC_SampleTime: //ADC_SampleTime_1Cycles5   采样时间为 1.5 周期
      //ADC_SampleTime_7Cycles5   采样时间为 7.5 周期
      //ADC_SampleTime_13Cycles5  采样时间为 13.5 周期
      //ADC_SampleTime_28Cycles5  采样时间为 28.5 周期
      //ADC_SampleTime_41Cycles5  采样时间为 41.5 周期
      //ADC_SampleTime_55Cycles5  采样时间为 55.5 周期
      //ADC_SampleTime_71Cycles5  采样时间为 71.5 周期
      //ADC_SampleTime_239Cycles5 采样时间为 239.5 周期 
 
  ADC_DMACmd(ADC1, ENABLE);
 
 
  ADC_Cmd(ADC1, ENABLE);

    
  ADC_ResetCalibration(ADC1);
 
  while(ADC_GetResetCalibrationStatus(ADC1));//等待ADC的校准寄存器被设置完毕

 
  ADC_StartCalibration(ADC1);
 
  while(ADC_GetCalibrationStatus(ADC1));
    
 
  ADC_SoftwareStartConvCmd(ADC1, ENABLE);

  AD_value=ADC_GetConversionValue(ADC1);//返回最近一次 ADCx 规则组的转换结果
  }

void DMA_Configuration(void)
{
DMA_DeInit(DMA_Channel1);
DMA_InitStructure.DMA_PeripheralBaseAddr = ADC1_DR_Address;      //定义DMA外设基地址
DMA_InitStructure.DMA_MemoryBaseAddr = (u32)&ADC_ConvertedValue; // 定义DMA内存基地址
DMA_InitStructure.DMA_DIR = DMA_DIR_PeripheralSRC;               //外设作为数据传输的来源(外设传到内存) DMA_DIR_PeripheralDST——内存传到外设
DMA_InitStructure.DMA_BufferSize = 3;                            //连续转化3个AD通道值
DMA_InitStructure.DMA_PeripheralInc = DMA_PeripheralInc_Disable; //外设寄存器地址不变
DMA_InitStructure.DMA_MemoryInc = DMA_MemoryInc_Enable;          //内存寄存器地址递增
DMA_InitStructure.DMA_PeripheralDataSize = DMA_PeripheralDataSize_Word; //外设数据宽度32bit
DMA_InitStructure.DMA_MemoryDataSize = DMA_MemoryDataSize_Word;    //内存数据宽度32bit
DMA_InitStructure.DMA_Mode = DMA_Mode_Circular;     //DMA模式是循环
DMA_InitStructure.DMA_Priority = DMA_Priority_High; //DMA优先级
DMA_InitStructure.DMA_M2M = DMA_M2M_Disable;       //DMA没有设置内存到内存传输
DMA_Init(DMA_Channel1, &DMA_InitStructure);

DMA_Cmd(DMA_Channel1, ENABLE);
}

 //RCC_APB1PeriphClockCmd(RCC_APB1Periph_DAC, ENABLE);
void DAC_Configuration(void)
    {
   DAC_InitTypeDef DAC_InitStructure;
  
      DAC_InitStructure.DAC_Trigger=DAC_Trigger_Software;         //DAC触发方式为软件控制
      DAC_InitStructure.DAC_WaveGeneration=DAC_WaveGeneration_None;      //不从DAC端口产生波形
      DAC_InitStructure.DAC_LFSRUnmask_TriangleAmplitude=DAC_LFSRUnmask_Bits8_0; //8位DA波形生成模式
      DAC_InitStructure.DAC_OutputBuffer=DAC_OutputBuffer_Enable;       //使能DAC输出缓冲器
                //用上面参数初始化DAC通道1
    DAC_Init(DAC_Channel_1, &DAC_InitStructure); 
      DAC_Cmd(DAC_Channel_1, ENABLE);        //使能DAC通道1
      DAC_Init(DAC_Channel_2, &DAC_InitStructure);           //用上面参数初始化DAC通道1
   DAC_Cmd(DAC_Channel_2, ENABLE);        //使能DAC通道2
DA的使用方式:
DAC_SetChannel2Data(DAC_Align_12b_L, DAC_data); //设置DAC通道1为12位且数据左对齐模式
         DAC_SoftwareTriggerCmd(DAC_Channel_2, ENABLE); //使能DAC通道1的软件触发方式,转换一次
         DAC_SetChannel1Data(DAC_Align_12b_L, DAC_data); //设置DAC通道1为12位且数据左对齐模式
         DAC_SoftwareTriggerCmd(DAC_Channel_1, ENABLE); //使能DAC通道1的软件触发方式,转换一次
}

 

关键字:ARM  常用函数  配置函数  重点积累 引用地址:ARM常用函数的配置函数---重点积累

上一篇:不用库函数自己动手配置STM32中的DMA
下一篇:10路AD驱动程序

推荐阅读最新更新时间:2024-03-16 14:36

基于ARM7的轨道检测仪的嵌入式系统设计
   1 引言   对铁路轨道进行静态几何参数的检测是铁路部门的一项常规工作,使用便携式轨道检测仪能大幅降低检测人员的工作量。这种智能测量技术不仅可以提高测量的精度和可信度,还能提供现场的和后续的轨道数据分析,极大的提高了轨道检测工作的质量和效率。便携式轨道测试仪对嵌入式计算机系统的功能和性能提出了许多新的需求:高实时性、高运算性能、高集成度、低功耗、低成本。传统单片机系统虽然能完成一般的控制任务,但其运算能力太低,不足以满足现场数据处理的要求,由基于SoC思想设计的ARM系列 微处理器 构成的嵌入式系统便能良好的满足上述要求。ARM核以高性能低功耗著称,再配以IC制造厂商提供的大量片上外设,使得ARM系列处理器拥有非常优良的
[单片机]
基于<font color='red'>ARM</font>7的轨道检测仪的嵌入式系统设计
格罗方德:已研发12nm FinFET封装的3D Arm芯片
8月10日消息 根据外媒Tom's Hardware的报道, GlobalFoundries (格罗方德)本周宣布,已经使用其12nm FinFET工艺成功制成了高性能的3D Arm芯片。 格罗方德表示:“这些高密度的3D芯片将为计算应用,如AI/ML(人工智能和机器学习)以及高端消费级移动和无线解决方案,带来新的性能和能源效率。” 据报道,格罗方德和Arm这两家公司已经验证了3D设计测试(DFT)方法,使用的是格罗方德的混合晶圆对晶圆键合。这项技术每平方毫米可支持多达100万个3D连接,使其具有高度可扩展性,并有望为12nm 3D芯片提供更长的使用寿命。 对于3D封装技术,英特尔去年宣布了其对3D芯片堆叠的研究,AM
[手机便携]
64位ARM处理器意味着什么?
   64位计算的历史相当丰富有趣。Cray等公司在70年代就已经开始在自己的系统当中使用64位寄存器,但真正纯粹的64位计算直到90年代才真正到来。 首先是MIPS的R4000,然后是DEC的Alpha处理器。到90年代中期,英特尔和Sun都已经拥有64位设计。而对于消费者来说,真正的转折点是 AMD在2003年发布了一款兼容英特尔32位x86处理器的64位PC处理器。 再向前快进10年,PC销量不断下滑,大部分智能手机和平板电脑都拥有了主频在1-2GHz之间的多核心处理器。但它们使用的都是32位架构,而非现代PC和服务器所使用的64位架构。到现在为止,这都是可以接受的。智能手机并不会去和PC拼性能,这些处理器需要足够节能,以
[手机便携]
医疗设备逐渐从X86转到ARM平台主要原因是什么
  x86概述   X86是由Intel推出的一种复杂指令集,用于控制芯片的运行的程序,现在X86已经广泛运用到了家用PC(机箱+xx主板+xx电源+xx处理器+(光驱选装)的领域。   x86架构于1978年推出的Intel 8086中央处理器中首度出现,它是从Intel 8008处理器中发展而来的,而8008则是发展自Intel 4004的。8086在三年后为IBM PC所选用,之后x86便成为了个人计算机的标准平台,成为了历来最成功的CPU架构。   x86架构是重要地可变指令长度的CISC(复杂指令集计算机,Complex InstrucTIon Set Computer)。字组(word, 4字节)长度的存储器访
[单片机]
医疗设备逐渐从X86转到<font color='red'>ARM</font>平台主要原因是什么
ARM 汇编命令参考AREA
1. AREA AREA 命令指示汇编程序汇编一个新的代码段或数据段。段是独立的、指定的、不可见的代码或数据块,它们由链接程序处理。 语法 AREA sectionname{,attr}{,attr}... 其中: sectionname 是将要指定的段名。 可以为段选择任何段名。但是,以一个数字开始的名称必须包含在竖杠号内,否则会产生一个缺失段名错误。例如,|1_DataArea|。 有些名称是习惯性的名称。例如,|.text| 用于表示由 C 编译程序产生的代码段,或用于以某种方式与 C 库关联的代码段。 attr 是一个或多个用逗号分隔的段属性
[单片机]
飞思卡尔携手 ARM 和 Oracle 为“一体化”IoT网关平台喜添全新垂直细分市场支持
三家公司还合作进行 ARM mbed 项目,简化物联网边缘/传感器节点开发 2013 年 10 月 29 日,美国圣克拉拉 (ARM® TechCon® 2013) 讯-随着市场对公共、开放和安全的物联网 (IoT) 服务交付基础设施(从云到网络边缘)的需求不断增加,飞思卡尔半导体 (NYSE: FSL)、ARM® 及 Oracle® 为新一代 IoT 服务提供商和边缘节点开发人员提供更多的细分市场解决方案组合,以响应市场需求。 飞思卡尔携手 ARM 和 Oracle 建立了一个安全的服务平台,为多个垂直市场标准化并巩固 IoT 服务交付与管理。飞思卡尔一体化平台完美结合了端到端软件与融合分层智能网关,为安全地交付和管理IoT
[单片机]
痞子衡嵌入式:ARM Cortex-M文件那些事(3)- 工程文件(.ewp)
  前面两节课里,痞子衡分别给大家介绍了嵌入式开发中的两种典型input文件:源文件(.c/.h/.s)、链接文件(.icf)。痞子衡要再次提问了,还有没有input文件呢?答案确实是有,但这次真的是有且仅有了,本文要介绍的主角project文件也属于半个input文件。为什么说是半个?因为project文件不仅包含开发者指定的input信息,还包含很多其他辅助调试的input/output信息,算是嵌入式开发中承前启后的文件。而本文侧重点在于project文件中与开发者应用相关的input信息,仅当得到了这些input信息,再加上前面介绍的source和linker文件,那么你就已经得到了application所有的信息,你可以
[单片机]
Ceva 加入 Arm Total Design 加速开发面向基础设施和非地面网络卫星的端到端 5G SoC
Ceva PentaG-RAN与Arm Neoverse计算子系统相结合,降低5G SoC开发成本并缩短上市时间,从而使双方客户受益 帮助智能边缘设备更可靠、更高效地连接、感知和推断数据的全球领先硅产品和软件IP授权许可厂商 Ceva公司宣布加入Arm Total Design ,旨在加速开发基于Arm® Neoverse™计算子系统(CSS)和Ceva PentaG-RAN 5G平台的端到端5G定制SoC,用于包括5G基站、Open RAN设备和5G非地面网络(NTN)卫星在内的无线基础设施。 Neoverse CSS 是经过优化、集成和验证的平台,能够以更低成本和更快上市时间实现定制硅片设计。 它与Ceva
[网络通信]
Ceva 加入 <font color='red'>Arm</font> Total Design  加速开发面向基础设施和非地面网络卫星的端到端 5G SoC
小广播
添点儿料...
无论热点新闻、行业分析、技术干货……
设计资源 培训 开发板 精华推荐

最新单片机文章
何立民专栏 单片机及嵌入式宝典

北京航空航天大学教授,20余年来致力于单片机与嵌入式系统推广工作。

换一换 更多 相关热搜器件
电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2024 EEWORLD.com.cn, Inc. All rights reserved