EDA365欢迎您登录!
您需要 登录 才可以下载或查看,没有帐号?注册
x
外部中断: 器件 HXS320F2803X支持三个屏蔽的外部中断(XINT1 - XINT3)。可以选择用上升 或 下降 和 上升边沿 触发,也可以选择 使能/禁用 这些中断,它还包含一个16位自由运行计数器,该计数器重置为零,可用于为中断准确地打上时间截。没有用于外部中断的专用引脚XINT1,XINT2和XINT3中断可以配置为GPI00 -GPI031引脚的输入。 首先将需要配置的GPIO端口配置为通用输入端口。上拉不上拉,采样次数和与不与系统时钟同步都无所谓,不会影响中断的配置。不过如果噪声过大的话,建议使能上拉和选择合适的输入采样滤波。以GPIO34为例,将其配置为上升沿触发XINT3的中断输入源。下面所有寄存器的配置受到EALLOW的保护,因此需要解除保护在进行设置。9 e( `7 b ^" U/ y
GpioCtrlRegs.GPBMUX1.bit.GPIO34 = 0; //相应端口配置为通用IO
8 k( Q% v" V/ t0 TGpioCtrlRegs.GPBDIR.bit.GPIO34 = 0; //输入
8 P7 j* E$ F/ WGpioCtrlRegs.GPBCTRL.bit.QUALPRD0 = 1; //输入滤波采样周期为2*1 Tsysclk(系统时钟)
- V5 `2 K. [5 H- O; L: Q: wGpioCtrlRegs.GPBQSEL1.bit.GPIO34 = 1; //三次采样! x& Q) N! Z8 X f8 @: R6 |6 x! u
GpioCtrlRegs.GPBPUD.bit.GPIO34 = 0; //使能内部上拉
% S" O/ z t D, P* H将GPIO配置到响应的中断源上
* ^! a) V: W6 [5 a4 E! d* ~GpioIntRegs.GPIOXINT3SEL.bit.GPIOSEL = 34;//选择34端口为外部中断3中断源 选择触发中断的方式。$ b, s* C8 W" \/ M3 i" {# Z- I& r* K
XIntruptRegs.XINT3CR.bit.POLARITY = 1; //上升沿触发, j) ?) b) R5 t2 b/ j. K
使能外部中断9 r- U+ \0 b9 [; ^ |4 `
XIntruptRegs.XINT3CR.bit.ENABLE = 1; //使能外部中断
8 e: L, O v! D最后使能PIE中断和CPU中断,如果需要还可以重新定义中断入口函数。
9 o7 g1 Q& c, B/ YPieCtrlRegs.PIEIER12.bit.INTx1 = 1; //使能PIE外部中断3) z) q; H$ _8 ?" F3 I
IER | = M_INT12; //使能第十二组CPU中断" r0 W" n0 _4 F1 A! \, x
PieVectTable.XINT3 = &Xint3_ISR; //从新定义中断入口函数
* {7 O2 y$ t) H
+ c$ l* K% C& f1 J定时器:, _3 ?8 s7 s2 j |: n
寄存器:' G) }# \, E3 A$ N- Y
tiMERxTIM 计数器低16位, [0 u; O# K: H
9 e0 U0 d) w0 M! E3 B# {
TIMERxPRDH 周期寄存器高16位* @: h' U9 F9 o& n: m
TIMERxPRO 周期寄存器低16位
w9 _, @( a+ K& L t ^
1 f4 X8 b) B* {+ UTIMERxTPRH 高8位PSCH、低8位TDDRH( B# @. u* O6 H! ]( W
TIMERxTPR 高8位PSC、低8位TDDR: f& v3 w. x5 j- D. k& N
! R; r O( w7 S4 d$ pTIMERxTCR 定时器控制寄存器
. f; S' { q/ v9 d位15 TIF 中断标志位 ,1有中断,0无中断2 h) @( j& Y$ |% ^8 }& w, @
位14 TIE 1允许中断,0禁止中断 n% D, }! c6 t* O- z
位 5 TRB 重载,1装载周期寄存器
( v( O& I& q* z/ G' z位 4 TSS 1停止定时器,0启动定时器 U* F9 }0 z& I. U; H/ K" X: J2 z
% {" L3 i+ X# ^' V$ O/ u
APWM模式:
0 d7 c4 d" J8 d0 S在apwm模式下,w_aprd = r_cap1,w_acmp = r_cap2,cap1代表周期,cap2代表cmp初始化r_apwm_out为0,cap模式下r_apwm_out始终为0,o_ecapen = 0; 通过CTR计数器分别与cap1周期,cap2的CMP相比较,在CTR = PRD与CTR= CMP时产生动作:e apwm模式下,r_tsctr =w_acmp.将r_apwm_out置0,r_tsctr = w_aprd.将r_apwm_out置1通过w_apwmpol选择极性后输出。 - a; a3 N% r$ K8 d
定时器中断:
B9 s+ Y8 ` x5 W5 q; a5 a 定时器寄存器介绍: 共分为三个Timer0/ Timer1/ Timer2寄存器, 每个模块由计数TIM.周期PRD, 控制TCR.预分频TPR组成。% C; }, h7 Q! h1 G& i* ?0 i5 Z
其中TCR控制15位为TIF中断标志,写1清除中断,14位TIE中断使能,5位TRB重装载控制,写1载入Timer计数与预分频初值,4位TSS暂停控制TIM计数值,减到零后会将TCR.TIF置位,并由TCR.TIF与TCR.TIE给出中断TPR 0-65535对应1-65536分频& d1 ]3 `6 Y- @! X7 M6 C; ]3 Y
|