本帖最后由 班炳炳 于 2024-5-21 23:15 编辑
#技术资源# #申请原创# 非常感谢雅特力官方给我这样一个测评的机会
芯片型号为AT32F405RCT7_7 主频高达216MHz,特色功能有:HS USB OTG (with PHY),FS USB OTG,12-bit 2 Msps 高速 ADC,QSPI / CAN / 8 UART / 3 SPI / 3 I2C,1 Full Duplex + 3 Half Duplex I2S,相关信息可以在雅特力官网查看
链接:https://www.arterytek.com/cn/product/AT32F405.jsp
点击下载资源即可跳转至资料下载板块
下载芯片数据手册,参考手册,开发板接口图,以及底层驱动源代码。
因为我使用的是Keil5 所以下载了相应的芯片包
解压后 双击进行安装
在Tool栏 AT的工具居然这么多样化 有AT32 IDE, AT32 Work Bench等,并配有详细的使用说明,更多工具大家可以到雅特力官网进行下载https://www.arterytek.com/cn/product/AT32F405.jsp
不得不说 雅特力的工具及资料真的非常齐全
准备好以上工作之后 就可以开始编程了
这里我准备使用ADC1 通道1通过软件触发采样并通过串口打印出来
使用Keil新建工程(步骤省略......)
主要代码如下
#include "at32f402_405_board.h"
#include "at32f402_405_clock.h"
crm_clocks_freq_type clocks_struct;
void USART_init(uint32_t baud);
void ADC_init(void);
uint32_t adc_result = 0;
float adc_value = 0.0;
int main(void)
{
system_clock_config();//系统时钟初始化
nvic_priority_group_config(NVIC_PRIORITY_GROUP_4);//设置中断分组
at32_board_init();//延时函数初始化
crm_clocks_freq_get(&clocks_struct);
USART_init(115200);//串口初始化函数
ADC_init();//ADC初始化函数
printf("test code.....!!!!\r\n");
printf("software_trigger_repeat \r\n");
while(1)
{
while(adc_flag_get(ADC1, ADC_CCE_FLAG) == RESET);//等待转换完成
adc_result = adc_ordinary_conversion_data_get(ADC1);
printf("adc_result = %d\r\n", adc_result);
adc_value = adc_result * 3.3 / 4095;
printf("adc_result = %0.2f\r\n", adc_value);
delay_ms(2000);
}
}
void ADC_init(void)
{
gpio_init_type gpio_initstructure;
adc_base_config_type adc_base_struct;
crm_periph_clock_enable(CRM_ADC1_PERIPH_CLOCK, TRUE);
crm_periph_clock_enable(CRM_GPIOA_PERIPH_CLOCK, TRUE);
gpio_default_para_init(&gpio_initstructure);//GPIO默认参数初始化
/* config adc pin as analog input mode */
gpio_initstructure.gpio_mode = GPIO_MODE_ANALOG;//模拟输入
gpio_initstructure.gpio_pins = GPIO_PINS_1;//ADC1通道1
gpio_init(GPIOA, &gpio_initstructure);
adc_clock_div_set(ADC_DIV_16);//ADC时钟16分频
adc_base_default_para_init(&adc_base_struct);//ADC默认参数初始化
adc_base_struct.sequence_mode = TRUE;//序列模式
adc_base_struct.repeat_mode = TRUE;//开启反复模式 每次触发转换一组通道 连续模式
adc_base_struct.data_align = ADC_RIGHT_ALIGNMENT;//数据右对齐
adc_base_struct.ordinary_channel_length = 1;//普通通道序列长度 1
adc_base_config(ADC1, &adc_base_struct);
/* ADC1初始化普通通道 1:将通道1放在ADC转换菜单的第一个位置 */
adc_ordinary_channel_set(ADC1, ADC_CHANNEL_1, 1, ADC_SAMPLETIME_41_5);//ADC采样时间41.5个周期
/* 普通通道转换组触发模式使能及触发事件选择 */
adc_ordinary_conversion_trigger_set(ADC1, ADC12_ORDINARY_TRIG_SOFTWARE, TRUE);//使用软件触发
/* adc enable */
adc_enable(ADC1, TRUE);//ADC1使能
/* adc calibration */
adc_calibration_init(ADC1);//ADC初始化校准
while(adc_calibration_init_status_get(ADC1));//初始化校准状态获取
adc_calibration_start(ADC1);//ADC校准开始
while(adc_calibration_status_get(ADC1));//ADC校准状态获取
/* 反复转换模式打开:软件触发使能之后会一直进行转换 */
/* 反复转换模式关闭:软件触发使能之后会转换一次就结束了 */
adc_ordinary_software_trigger_enable(ADC1, TRUE);//软件触发使能打开
}
void USART_init(uint32_t baud)
{
gpio_init_type gpio_init_struct;
crm_periph_clock_enable(CRM_USART1_PERIPH_CLOCK, TRUE);//开启串口1时钟
crm_periph_clock_enable(CRM_GPIOA_PERIPH_CLOCK, TRUE);//开启GPIOA时钟
gpio_default_para_init(&gpio_init_struct);
/* configure the TX pin */
gpio_init_struct.gpio_drive_strength = GPIO_DRIVE_STRENGTH_MODERATE;//适中电流推动
gpio_init_struct.gpio_out_type = GPIO_OUTPUT_PUSH_PULL;//推挽输出
gpio_init_struct.gpio_mode = GPIO_MODE_MUX;//复用模式
gpio_init_struct.gpio_pins = GPIO_PINS_9;
gpio_init_struct.gpio_pull = GPIO_PULL_NONE;//无上下拉
gpio_init(GPIOA, &gpio_init_struct);
gpio_pin_mux_config(GPIOA, GPIO_PINS_SOURCE9, GPIO_MUX_7);//配置引脚复用功能
/* configure the RX pin */
gpio_init_struct.gpio_drive_strength = GPIO_DRIVE_STRENGTH_MODERATE;//适中电流推动
gpio_init_struct.gpio_out_type = GPIO_OUTPUT_PUSH_PULL;//推挽输出
gpio_init_struct.gpio_mode = GPIO_MODE_MUX;//复用模式
gpio_init_struct.gpio_pins = GPIO_PINS_10;
gpio_init_struct.gpio_pull = GPIO_PULL_NONE;//无上下拉
gpio_init(GPIOA, &gpio_init_struct);
gpio_pin_mux_config(GPIOA, GPIO_PINS_SOURCE10, GPIO_MUX_7);
/* configure param */
usart_init(USART1, baud, USART_DATA_8BITS, USART_STOP_1_BIT);//波特率 8位数据位 1位停止位
usart_transmitter_enable(USART1, TRUE);//发送使能
usart_receiver_enable(USART1, TRUE);//接收使能
usart_parity_selection_config(USART1, USART_PARITY_NONE);//无奇偶校验
usart_hardware_flow_control_set(USART1, USART_HARDWARE_FLOW_NONE);//无需硬件流控
usart_enable(USART1, TRUE);
}
输出结果如下
|