APB信号说明及波形示例

概述

APB功耗低、复杂度低;

APB协议不是pipeline的,用来连接带宽较低的外设;

APB每次传输至少需要消耗2cycles;

APB信号介绍

信号

源头

描述

PCLK

Clock source

APB在PCLK上升沿时发生传输

PRESETn

System Bus

低复位

PADDR

Master

APB地址信号

PPROT

Master

保护类型。分为normal、privileged和secure保护类型;

PSELx

Master

选择信号;

PENBLE

Master

使能信号;指示一次传输的第2个或者接下来的cycles;

PWRITE

Master

写信号;1:表示写操作;0:读操作;

PWDATA

Master

写数据;

PSTRB

Master

写选通脉冲;表示某个字节数据有效;

PREADY

Slave

Ready信号

PRDATE

Slave

读数据信号

PSLVERR

Slave

该信号指示传输失败

PRROT信号编码说明

写传输示例

 

    在T2时刻,PSEL为1,PWRITE、PADDR和PWDATA被寄存起来。此后PENABLE被置为1,等待PREADY拉起;T5时刻PREADY被拉起来,数据被写入Slave。

读传输示例

     在T2时刻,PSEL被拉起,PWRITE和PADDR被寄存起来;此后PENABLE被拉起等待PREADY拉起;T5时刻PREADY被拉起来,PRDATA被Master获取,读操作完成。

 APB传输处理状态机

    APB整体处理如上图所示。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
这个项目需要以下材料: - STM32开发板 - ADC模块 - DAC模块 - LCD显示屏 - 电源线 - 杜邦线 步骤: 1. 连接ADC模块和DAC模块到STM32开发板上。 2. 在STM32开发环境中,创建一个新工程。 3. 配置ADC模块和DAC模块的引脚,使它们能够正确连接到STM32开发板上。 4. 编写程序,使ADC模块采集正弦波信号,并将其传递给DAC模块输出。 5. 使用LCD显示屏显示正弦波信号。 下面是一个简单的代码示例,可以帮助你开始该项目: ``` #include "stm32f10x.h" #include "stm32f10x_adc.h" #include "stm32f10x_dac.h" #include "stm32f10x_gpio.h" #include "stm32f10x_rcc.h" #include "stm32f10x_tim.h" #include "stm32f10x_usart.h" #define ADC1_DR_Address ((uint32_t)0x4001244C) volatile uint16_t ADC_Value = 0; void ADC_Configuration(void) { ADC_InitTypeDef ADC_InitStructure; GPIO_InitTypeDef GPIO_InitStructure; RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA | RCC_APB2Periph_ADC1, ENABLE); GPIO_InitStructure.GPIO_Pin = GPIO_Pin_0; GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AIN; GPIO_Init(GPIOA, &GPIO_InitStructure); ADC_InitStructure.ADC_Mode = ADC_Mode_Independent; ADC_InitStructure.ADC_ScanConvMode = DISABLE; ADC_InitStructure.ADC_ContinuousConvMode = ENABLE; ADC_InitStructure.ADC_ExternalTrigConv = ADC_ExternalTrigConv_None; ADC_InitStructure.ADC_DataAlign = ADC_DataAlign_Right; ADC_InitStructure.ADC_NbrOfChannel = 1; ADC_Init(ADC1, &ADC_InitStructure); ADC_Cmd(ADC1, ENABLE); ADC_RegularChannelConfig(ADC1, ADC_Channel_0, 1, ADC_SampleTime_71Cycles5); } void DAC_Configuration(void) { DAC_InitTypeDef DAC_InitStructure; GPIO_InitTypeDef GPIO_InitStructure; RCC_APB1PeriphClockCmd(RCC_APB1Periph_DAC, ENABLE); RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA, ENABLE); GPIO_InitStructure.GPIO_Pin = GPIO_Pin_4; GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AIN; GPIO_Init(GPIOA, &GPIO_InitStructure); DAC_InitStructure.DAC_Trigger = DAC_Trigger_None; DAC_InitStructure.DAC_WaveGeneration = DAC_WaveGeneration_None; DAC_InitStructure.DAC_OutputBuffer = DAC_OutputBuffer_Enable; DAC_Init(DAC_Channel_1, &DAC_InitStructure); DAC_Cmd(DAC_Channel_1, ENABLE); } void TIM_Configuration(void) { TIM_TimeBaseInitTypeDef TIM_TimeBaseStructure; RCC_APB1PeriphClockCmd(RCC_APB1Periph_TIM2, ENABLE); TIM_TimeBaseStructure.TIM_Period = 1000; TIM_TimeBaseStructure.TIM_Prescaler = 72 - 1; TIM_TimeBaseStructure.TIM_ClockDivision = 0; TIM_TimeBaseStructure.TIM_CounterMode = TIM_CounterMode_Up; TIM_TimeBaseInit(TIM2, &TIM_TimeBaseStructure); TIM_Cmd(TIM2, ENABLE); TIM_ITConfig(TIM2, TIM_IT_Update, ENABLE); } void LCD_Configuration(void) { /* 初始化LCD */ } int main(void) { ADC_Configuration(); DAC_Configuration(); TIM_Configuration(); LCD_Configuration(); while (1) { ADC_SoftwareStartConvCmd(ADC1, ENABLE); while (ADC_GetFlagStatus(ADC1, ADC_FLAG_EOC) == RESET); ADC_Value = ADC_GetConversionValue(ADC1); DAC_SetChannel1Data(DAC_Align_12b_R, ADC_Value); } } void TIM2_IRQHandler(void) { if (TIM_GetITStatus(TIM2, TIM_IT_Update) != RESET) { /* 在LCD上显示正弦波信号 */ TIM_ClearITPendingBit(TIM2, TIM_IT_Update); } } ``` 这只是一个简单的示例,你需要根据实际情况来完善代码。同时,你还需要连接LCD显示屏并编写相应的显示代码。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值