1 /******************************************************************************************************************************************
2 * 文件名称: SWM341_iofilt.c
3 * 功能说明: SWM341单片机的IO滤波器功能模块,对PAD到模块输入间的信号滤波,窄于指定宽度的脉冲视作毛刺,忽略
4 * 技术支持: http://www.synwit.com.cn/e/tool/gbook/?bid=1
5 * 注意事项:
6 * 版本日期: V1.0.0 2016年1月30日
7 * 升级记录:
8 *
9 *
10 *******************************************************************************************************************************************
11 * @attention
12 *
13 * THE PRESENT FIRMWARE WHICH IS FOR GUIDANCE ONLY AIMS AT PROVIDING CUSTOMERS WITH CODING INFORMATION
14 * REGARDING THEIR PRODUCTS IN ORDER FOR THEM TO SAVE TIME. AS A RESULT, SYNWIT SHALL NOT BE HELD LIABLE
15 * FOR ANY DIRECT, INDIRECT OR CONSEQUENTIAL DAMAGES WITH RESPECT TO ANY CLAIMS ARISING FROM THE CONTENT
16 * OF SUCH FIRMWARE AND/OR THE USE MADE BY CUSTOMERS OF THE CODING INFORMATION CONTAINED HEREIN IN CONN-
17 * -ECTION WITH THEIR PRODUCTS.
18 *
19 * COPYRIGHT 2012 Synwit Technology
20 *******************************************************************************************************************************************/
21 #include "SWM341.h"
22 #include "SWM341_iofilt.h"
23
24
25 static uint32_t Width[2];
26
27
28 /******************************************************************************************************************************************
29 * 函数名称: IOFILT_Init()
30 * 功能说明: IO滤波器初始化
31 * 输 入: uint32_t IOFILTn 要初始化的滤波器,可取值 0-1
32 * uint32_t signal 要对哪个信号进行滤波操作,可取值 IOFILT0_PB5、IOFILT0_PB4、...
33 * uint32_t width 被选信号上宽度小于 width 个 HRC 时钟周期的脉冲被视作毛刺,过滤掉,可取值 IOFILT_WIDTH_2、IOFILT_WIDTH_4、...
34 * 输 出: 无
35 * 注意事项: 无
36 ******************************************************************************************************************************************/
IOFILT_Init(uint32_t IOFILTn,uint32_t signal,uint32_t width)37 void IOFILT_Init(uint32_t IOFILTn, uint32_t signal, uint32_t width)
38 {
39 SYS->CLKSEL &= ~SYS_CLKSEL_IOFILT_Msk;
40 SYS->CLKSEL |= (0 << SYS_CLKSEL_IOFILT_Pos); //滤波器时钟源:HRC
41
42 SYS->CLKEN1 |= (1 << SYS_CLKEN1_IOFILT_Pos);
43
44 *(&SYS->IOFILT0 + IOFILTn) = (signal << SYS_IOFILT_IOSEL_Pos) |
45 (0 << SYS_IOFILT_CLKDIV_Pos) |
46 (width << SYS_IOFILT_TIM_Pos);
47
48 Width[IOFILTn] = width;
49 }
50
51 /******************************************************************************************************************************************
52 * 函数名称: IOFILT_Open()
53 * 功能说明: IO滤波器开启
54 * 输 入: uint32_t IOFILTn 要初始化的滤波器,可取值 0-1
55 * 输 出: 无
56 * 注意事项: 无
57 ******************************************************************************************************************************************/
IOFILT_Open(uint32_t IOFILTn)58 void IOFILT_Open(uint32_t IOFILTn)
59 {
60 *(&SYS->IOFILT0 + IOFILTn) |= (Width[IOFILTn] << SYS_IOFILT_TIM_Pos);
61 }
62
63 /******************************************************************************************************************************************
64 * 函数名称: IOFILT_Close()
65 * 功能说明: IO滤波器关闭,即不滤波,PAD上的信号直接进入模块
66 * 输 入: uint32_t IOFILTn 要初始化的滤波器,可取值 0-1
67 * 输 出: 无
68 * 注意事项: 无
69 ******************************************************************************************************************************************/
IOFILT_Close(uint32_t IOFILTn)70 void IOFILT_Close(uint32_t IOFILTn)
71 {
72 *(&SYS->IOFILT0 + IOFILTn) &= ~SYS_IOFILT_TIM_Msk;
73 }
74