stevetong459 fb61c7960b
本次PR涉及①BSP驱动新增②F103库更新③GCC、IAR适配及MDK更新④README文件及由更新驱动引起的脚本改动。 (#5638)
* 本次提交包括①BSP驱动新增②F103库更新③GCC、IAR适配及MDK更新④README文件及由更新驱动引起的脚本改动。
详情如下:
一、BSP驱动新增
这是本次PR的主要目的,现新增了如下BSP驱动:
ADC、DAC、RTC、PWM、HWTIMER、I2C、SPI和WDT等八个驱动文件。
二、F103库更新:
本次提交使用2022年3月初极海官网发布的最新F103库,主要增加了版权声明、USB驱动及其他代码调整。
三、编译器适配:
1、新增GCC编译支持,在ENV工具下编译能成功且输出的bin文件能够使开发板闪灯。
2、新增IAR工程支持。
3、由F103的SDK更新,MDK的工程也进行了相应更新。
四、其他
1、README文件做了修改,加入了scons编译后的jlink下载说明和官网链接。
2、Kconfig、SConscript脚本根据驱动更新做了修改。

* 格式化代码(AStyle + Formatting)

* 增加BSP APM版权声明

* 在ci添加当前bsp的路径,以能够验证gcc能否正常编译

* 路径的“\”改为“/”
2022-03-08 12:03:06 +08:00

151 lines
3.5 KiB
C

/*
* Copyright (c) 2006-2022, RT-Thread Development Team
*
* SPDX-License-Identifier: Apache-2.0
*
* Change Logs:
* Date Author Notes
* 2022-03-04 stevetong459 first version
*/
#include <board.h>
#include <sys/time.h>
#ifdef RT_USING_WDT
#define DBG_TAG "drv.wdt"
#define DBG_LVL DBG_INFO
#include <rtdbg.h>
#ifndef LSI_VALUE
#define LSI_VALUE ((uint32_t)40000)
#endif
#define DRV_WDT_TIME_OUT 0xFFFF
typedef struct
{
struct rt_watchdog_device wdt;
rt_uint32_t min_threshold;
rt_uint32_t max_threshold;
rt_uint32_t current_threshold;
} apm32_wdt_t;
static apm32_wdt_t wdt_config;
static rt_err_t _iwdt_init(rt_watchdog_t *wdt)
{
rt_uint32_t counter = 0;
RCM_EnableLSI();
while (!RCM_ReadStatusFlag(RCM_FLAG_LSIRDY))
{
if (++counter > DRV_WDT_TIME_OUT)
{
LOG_E("LSI clock open failed.");
return -RT_ERROR;
}
}
wdt_config.min_threshold = 1;
wdt_config.max_threshold = (0xfff << 8) / LSI_VALUE;
LOG_I("threshold section [%u, %d]", \
wdt_config.min_threshold,
wdt_config.max_threshold);
while (IWDT_ReadStatusFlag(IWDT_FLAG_PSCU))
{
if (++counter > DRV_WDT_TIME_OUT)
{
LOG_E("watchdog prescaler init failed.");
return -RT_ERROR;
}
}
IWDT_EnableWriteAccess();
IWDT_ConfigDivider(IWDT_DIVIDER_256);
IWDT_DisableWriteAccess();
return RT_EOK;
}
/**
* @brief This function will control watchdog device.
*
* @param wdt is a pointer to i2c config class.
*
* @return RT_EOK indicates successful , other value indicates failed.
*/
static rt_err_t _iwdt_control(rt_watchdog_t *wdt, int cmd, void *arg)
{
volatile rt_uint32_t param, counter = 0;
switch (cmd)
{
case RT_DEVICE_CTRL_WDT_KEEPALIVE:
IWDT_Refresh();
break;
case RT_DEVICE_CTRL_WDT_SET_TIMEOUT:
param = *(rt_uint32_t *) arg;
if ((param > wdt_config.max_threshold) || \
(param < wdt_config.min_threshold))
{
LOG_E("invalid param@%u.", param);
return -RT_ERROR;
}
else
{
wdt_config.current_threshold = param;
}
while (IWDT_ReadStatusFlag(IWDT_FLAG_CNTU))
{
if (++counter > DRV_WDT_TIME_OUT)
{
LOG_E("Update watchdog reload value complete.");
return -RT_ERROR;
}
}
IWDT_Refresh();
IWDT_EnableWriteAccess();
IWDT_ConfigReload(param * LSI_VALUE >> 8);
IWDT_DisableWriteAccess();
break;
case RT_DEVICE_CTRL_WDT_GET_TIMEOUT:
*(rt_uint32_t *)arg = wdt_config.current_threshold;
break;
case RT_DEVICE_CTRL_WDT_START:
IWDT_Enable();
IWDT_Refresh();
break;
default:
LOG_W("This command is not supported.");
return -RT_ERROR;
}
return RT_EOK;
}
static struct rt_watchdog_ops _wdt_ops =
{
_iwdt_init,
_iwdt_control,
};
static int rt_hw_wdt_init(void)
{
wdt_config.wdt.ops = &_wdt_ops;
/* register watchdog device */
if (rt_hw_watchdog_register(&wdt_config.wdt, "wdt", \
RT_DEVICE_FLAG_DEACTIVATE, RT_NULL) != RT_EOK)
{
LOG_E("wdt device register failed.");
return -RT_ERROR;
}
LOG_D("wdt device register success.");
return RT_EOK;
}
INIT_BOARD_EXPORT(rt_hw_wdt_init);
#endif