AT32F435ZGT7使用教程一(移植RT-Thread,更改外部晶振)

 第一步,下载野火的AT32例程。

   链接:https://pan.baidu.com/s/1I8QjRT1-EjZIiYri1rgDGw?pwd=AT32 
   提取码:AT32

第二步,去雅特力官网下载芯片支持包,并进行安装

  https://www.arterytek.com/file/download/1691

第三步,打开野火的LED例程,修改芯片型号。

第三步,修改系统时钟
       在user文件夹中打开at32f435_437_clock.c文件。找到void system_clock_config(void)函数,根据外部晶振频率进行修改 ,我使用12M外部晶振。288M系统时钟频需要修改为crm_pll_config(CRM_PLL_SOURCE_HEXT, 96, 1, CRM_PLL_FR_4);

具体公式如下:PLLCLK:PLL时钟 = PLL输入时钟 / PLL_MS * PLL_NS / PLL_FR。

                                           288=12/1 *96 /4

第四步,点开at32f435_437_clock.c下的文件,找到打开at32f435_437_conf.h文件。修改为
                  #define HEXT_VALUE                       ((uint32_t)12000000)

此时程序便可以正常启用。

第五步,移植RT-Thread。

  按照这个文章进行移植,http://t.csdnimg.cn/toiPy

串口程序修改为:

#include "bsp_usart.h"
#include "board.h"

void usart_config(void)
{
  gpio_init_type gpio_init_struct;
	
	/* 使能对应端口的时钟 */
  crm_periph_clock_enable(USART_CRM_CLK, TRUE);
	crm_periph_clock_enable(USART_GPIO_CRM_CLK, TRUE);
	/* 默认填充配置 */
  gpio_default_para_init(&gpio_init_struct);
	
	/* 设置 GPIO 驱动能力较大电流推动/吸入能力 */
  gpio_init_struct.gpio_drive_strength = GPIO_DRIVE_STRENGTH_STRONGER;
	/* 设置 GPIO 输出类型为推挽输出模式 */
  gpio_init_struct.gpio_out_type  = GPIO_OUTPUT_PUSH_PULL;
	/* 设置 GPIO 模式为复用模式 */
  gpio_init_struct.gpio_mode = GPIO_MODE_MUX;
	/* 配置 GPIO 引脚 */
  gpio_init_struct.gpio_pins = USART_TX_PIN;
	/* 设置 GPIO 无上下拉模式 */
  gpio_init_struct.gpio_pull = GPIO_PULL_NONE;
	/* 初始化 GPIO 外设 */
  gpio_init(USART_TX_GPIO, &gpio_init_struct);

  gpio_init_struct.gpio_pins = USART_RX_PIN;
  gpio_init(USART_RX_GPIO, &gpio_init_struct);
	
	/* 配置引脚复用功能 */
	gpio_pin_mux_config(USART_TX_GPIO, USART_TX_PIN_SOURCE, USART_TX_PIN_MUX_NUM);
	gpio_pin_mux_config(USART_RX_GPIO, USART_RX_PIN_SOURCE, USART_RX_PIN_MUX_NUM);
	
	/* 波特率 数据位 停止位配置 */
  usart_init(USART1, 115200, USART_DATA_8BITS, USART_STOP_1_BIT);
	
	/* 中断优先级分组配置 */
//	nvic_priority_group_config(NVIC_PRIORITY_GROUP_1);
	/* 中断使能及优先级配置 */
//  nvic_irq_enable(USARTX_IRQn, 0,1);

  /* 发送使能 */
  usart_transmitter_enable(USART1, TRUE);
	/* 接收使能 */
  usart_receiver_enable(USART1, TRUE);
  /* 中断使能 */	
//	usart_interrupt_enable(USART1,USART_RDBF_INT, TRUE);
  /* 串口使能 */
  usart_enable(USART1, TRUE);
}



///*****************  发送一个字符 **********************/
void Usart_SendByte( usart_type * pUSARTx, uint8_t ch)
{
	/* 发送一个字节数据到USART */
	usart_data_transmit(pUSARTx,ch);
		
	/* 等待发送数据寄存器为空 */
	while (usart_flag_get(pUSARTx, USART_TDBE_FLAG) == RESET);	
}

/*****************  发送字符串 **********************/
void Usart_SendString( usart_type * pUSARTx, char *str)
{
	unsigned int k=0;
  do 
  {
      Usart_SendByte( pUSARTx, *(str + k) );
      k++;
  } while(*(str + k)!='\0');
  
  /* 等待发送完成 */
  while(usart_flag_get(pUSARTx,USART_TDC_FLAG)==RESET)
  {}
}


int fputc(int ch, FILE *f)
{
	  usart_data_transmit(USART1, (uint8_t) ch);	
		while (usart_flag_get(USART1, USART_TDBE_FLAG) == RESET);			
		return (ch);
}

int fgetc(FILE *f)
{
		while (usart_flag_get(USART1, USART_RDBF_FLAG) == RESET);
		return (int)usart_data_receive(USART1);
}



//*************************************************************//
// 系统rt_kprintf()函数是通过调用 rt_hw_console_output();来实现
// 而rt_hw_console_output();函数系统默认是没有实现的,所以如果要
// 使用rt_kprintf()函数,就需要用户自己实现rt_hw_console_output()函数
// 实现rt_hw_console_output()函数的前提是,要初始化串口功能,串口初始化
// 过程和裸机串口初始化过程完全一样
//************************************************************//
/**
  * @brief  重映射串口DEBUG_USARTx到rt_kprintf()函数
  *   Note:DEBUG_USARTx是在bsp_usart.h中定义的宏,默认使用串口1
  * @param  str:要输出到串口的字符串
  * @retval 无
  *
  * @attention
  *
  */
void rt_hw_console_output( const char *str )
{
    /* 进入临界段 */
    rt_enter_critical();
 
    /* 直到字符串结束 */
    while ( *str != '\0' )
    {
        /* 换行 */
        //RT-Thread 系统中已有的打印均以 \n 结尾,而并非 \r\n,所以在字符输出时,需要在输出 \n 之前输出 \r,完成回车与换行,否则系统打印出来的信息将只有换行
        if ( *str == '\n' )
        {
            usart_data_transmit( DEBUG_USARTx, '\r' );
            while (usart_flag_get(DEBUG_USARTx, USART_TDBE_FLAG) == RESET);//发送完成标志
        }
        usart_data_transmit( DEBUG_USARTx, *str++ );
        while ( usart_flag_get( DEBUG_USARTx, USART_TDBE_FLAG ) == RESET );//发送完成标志
    }
 
    /* 退出临界段 */
    rt_exit_critical();
}

//使用Finsh组件三步骤:
//1.实现该函数及rt_hw_console_output函数;
//2.rtconfig.h中开启RT_USING_FINSH宏;
//3.添加Finsh组件(cmd.c、msh.c、shell.c);
char rt_hw_console_getchar( void )
{
    //查询方式实现,记得将Usart1初始化中的中断接收配置相关代码注释掉
    int ch = -1;
    /*等待串口1输入数据*/
    if( usart_flag_get( DEBUG_USARTx, USART_RDBF_FLAG ) != RESET )
    {
        ch = ( int )usart_data_receive( DEBUG_USARTx );
        usart_flag_clear( DEBUG_USARTx, USART_RDBF_FLAG );
    }
    else
    {
        if( usart_flag_get( DEBUG_USARTx, USART_ROERR_FLAG ) != RESET )
        {
		
            usart_flag_clear( DEBUG_USARTx, USART_ROERR_FLAG );
        }
        rt_thread_mdelay( 10 );
    }
    return ch;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值