版主
主题
回帖0
积分10609
阅读权限200
注册时间2008-11-22
最后登录1970-1-1
在线时间 小时
|
楼主 |
发表于 2019-3-1 15:18
|
显示全部楼层
ZYNQ采用了结构指针加函数指针来实现复杂的功能还有它总之采用强制转换来实现类型转换,所以好多用了void ** i; l8 L. I0 l! K. i& n/ {
4 X5 U& [- g$ V* ]$ l T& t$ w
7 s: c& ~) ^1 @#include <stdio.h>
5 ` v% h6 U: [' j#include "xscugic.h"
6 M8 J' t/ ~9 r6 a; V#include "xil_exception.h"
4 U' N7 |3 w# \+ e, R" ?6 P6 F% K& }, u
#define INT_CFG0_OFFSET 0x00000C00
# ^: }' Z3 K0 P' L+ @7 m/ X; m+ L3 p
// Parameter definitions
; C4 J9 D+ ]# U) j' ]#define SW1_INT_ID 61) f" @& L7 M; [$ m9 |
#define SW2_INT_ID 62
4 |& b: q+ ~. Q6 b/ S# X6 I0 N#define SW3_INT_ID 63% e+ g# U Z/ \, P R
#define INTC_DEVICE_ID XPAR_PS7_SCUGIC_0_DEVICE_ID P; K' m& z8 [( J" }+ L& k$ O; n
#define INT_TYPE_RISING_EDGE 0x03
9 V% x0 c; I7 H( R#define INT_TYPE_HIGHLEVEL 0x01
) `% m7 s# t ~' A9 w: a' ~#define INT_TYPE_MASK 0x03- _' h' v- A4 R1 p1 I% d2 Q$ D
2 u& _$ w% h2 a1 U2 {
static XScuGic INTCInst;
& j0 C( e( h2 ~" Q' v! x& C. S
& s1 ^& K% y, x9 I0 Lstatic void SW_intr_Handler(void *param);
4 e3 v0 \0 D5 Gstatic int IntcInitFunction(u16 DeviceId);
: v. I3 R& l0 P, i
1 v& h0 V0 F+ C$ Y; @9 L+ W& ]static void SW_intr_Handler(void *param); b) |8 _. q) w% J" y: s- S# P
{% d* E5 j8 |( [5 i6 {
int sw_id = (int)param;
6 c1 D+ z* [' c% h' `: c& W printf("SW%d int\n\r", sw_id);3 f; ?7 q' @% G' }3 t5 b5 ~
}
' u3 e9 W5 q5 v# H2 x7 r5 Q0 A7 H7 O3 q& z5 H8 l
void IntcTypeSetup(XScuGic *InstancePtr, int intId, int intType)
/ D- R. ~! Y8 {% v4 i9 E6 S7 r7 ` W{
% y- P# m1 a& ]1 M" G int mask;4 b( L5 ^ `: R0 H6 B
9 d# F- t& g$ r# z
intType &= INT_TYPE_MASK;
4 [0 w9 Y5 c: f8 p' U6 R! ? mask = XScuGic_DistReadReg(InstancePtr, INT_CFG0_OFFSET + (intId/16)*4);
/ Q$ f r# p+ o/ w7 m mask &= ~(INT_TYPE_MASK << (intId%16)*2);
8 C* ^/ \- ~8 l7 n R& z mask |= intType << ((intId%16)*2);
% ] z! L/ V& i- ^, C XScuGic_DistWriteReg(InstancePtr, INT_CFG0_OFFSET + (intId/16)*4, mask);
% ]: t. R/ C$ Q. c2 @8 D! d8 s}
& O# H2 [/ w6 L+ z% k; T# q8 _2 z: Q+ q: }: H# A" L, O2 \1 z# d/ C
int IntcInitFunction(u16 DeviceId)1 J0 z- w V2 y8 t) O4 M
{# P. I/ L2 M$ |" I" ?; D
XScuGic_Config *IntcConfig;2 x" n) O/ C, g2 F
int status;$ K+ v0 S( [1 t$ y8 Y) _! y# Y
, @2 K; @0 C, U0 |, i
// Interrupt controller initialisation) `2 @# }6 r+ E, g( \) n
IntcConfig = XScuGic_LookupConfig(DeviceId);& I! j% S6 a9 j6 D6 z) ?. B
status = XScuGic_CfgInitialize(&INTCInst, IntcConfig, IntcConfig->CpuBaseAddress);1 `. v& @4 J' g( |. A# N% m
if(status != XST_SUCCESS) return XST_FAILURE;, h4 b3 O' [& N0 P
. m1 c0 R, b, V9 I) a
// Call to interrupt setup
9 {2 Q; f& j+ d+ V+ B& t Xil_ExceptionRegisterHandler(XIL_EXCEPTION_ID_INT,
6 }0 a& ~/ O4 q (Xil_ExceptionHandler)XScuGic_InterruptHandler,
G7 w3 X4 w! u5 c {& @& U" B- } &INTCInst);
7 g7 F- C8 B; l2 I! o Xil_ExceptionEnable();
, e1 w1 E5 y" v
" P: E" O' e7 B: w9 t9 ` m; { // Connect SW1~SW3 interrupt to handler
' c$ {9 m! C+ a( g1 }5 D T status = XScuGic_Connect(&INTCInst,
6 W; l7 ]1 o0 `5 v5 w4 C' m. Z# i* t SW1_INT_ID,/ s i4 W7 |" k7 {& y, y9 s
(Xil_ExceptionHandler)SW_intr_Handler,8 J7 O, B5 ~) c9 l( Q
(void *)1);% e: g; F3 N$ P ?2 Y( w& ~' U
if(status != XST_SUCCESS) return XST_FAILURE;
. a2 n% a9 v9 Y( ^, n6 P$ u$ I; U6 r# W1 ]- T4 }( }
status = XScuGic_Connect(&INTCInst,
# B! O; s( F' p, j SW2_INT_ID,
) z" G: f0 W- _6 u' p, M" t+ v (Xil_ExceptionHandler)SW_intr_Handler,5 p! e1 h. R" y) H0 d. |+ U; ~
(void *)2);
6 x q7 A$ t1 a+ r6 ?0 j- l/ M& o1 D if(status != XST_SUCCESS) return XST_FAILURE;& B* e% j; I, }! G" ^: k. g
6 X4 R1 d8 O5 I: ?* n status = XScuGic_Connect(&INTCInst,
: x5 H& o, H" L) D' w, p O3 a SW3_INT_ID,7 l7 |: N; e8 h* y$ d$ F
(Xil_ExceptionHandler)SW_intr_Handler,
8 z1 }/ o# T: f: d6 b (void *)3);
. [% i( f* q3 T( |$ x% C% | if(status != XST_SUCCESS) return XST_FAILURE;3 J( b; V4 ~: s% Q
( m' F: D$ l( U6 h // Set interrupt type of SW1~SW3 to rising edge$ U3 g: a5 \2 T) U. d
IntcTypeSetup(&INTCInst, SW1_INT_ID, INT_TYPE_RISING_EDGE);. p# o, V+ ^, D
IntcTypeSetup(&INTCInst, SW2_INT_ID, INT_TYPE_RISING_EDGE);3 P/ j" W; h3 a6 X2 b
IntcTypeSetup(&INTCInst, SW3_INT_ID, INT_TYPE_RISING_EDGE);
8 G% Z+ e# O7 u% X/ L. n7 M! n7 R
1 m0 }" f, r( b' Q4 }# k // Enable SW1~SW3 interrupts in the controller. U* z) O& P: W) _) q% G
XScuGic_Enable(&INTCInst, SW1_INT_ID);8 J8 R* r$ I- B T" O
XScuGic_Enable(&INTCInst, SW2_INT_ID);
+ g, B; v8 `/ S3 G: |4 _/ P XScuGic_Enable(&INTCInst, SW3_INT_ID);+ c \. F4 s/ [7 F; D, i2 H
7 m' k6 s" \ C) w7 C& U& N! ]! d& t
return XST_SUCCESS;0 q, F) B' Y5 F/ J- @- L
}6 {* s0 H& {9 \' i- k
2 R9 b. h& T5 j( }int main(void)
h, Q3 p0 l' `+ E) u- F{' ], i& _; v9 J) g# e
print("PL int test\n\r");6 z# H* m* v* F/ M/ n
IntcInitFunction(INTC_DEVICE_ID);3 w4 y# S2 a) L
while(1);) W. _$ \5 G* H @$ Z5 z
return 0;3 @% N$ T3 N1 ]- m8 Y0 c1 {, Y" M: [
}
" k9 O+ S( r, ^* X7 Y! k6 l- U' y3 u
# {4 C% H! z% M" l( e
5 ]2 I7 Q8 @( Z: q. r1 _
|
|