-
Notifications
You must be signed in to change notification settings - Fork 3
Expand file tree
/
Copy pathmain.c
More file actions
42 lines (31 loc) · 805 Bytes
/
main.c
File metadata and controls
42 lines (31 loc) · 805 Bytes
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
#include "platform.h"
#include "xfir.h"
#include "xil_printf.h"
int main()
{
print("\n\rFIR Filter\n\r>");
XFir fir =
{
.Control_BaseAddress = XPAR_FIR_0_S_AXI_CONTROL_BASEADDR,
.IsReady = 0
};
init_platform();
XFir_Config* const config = XFir_LookupConfig(XPAR_FIR_0_DEVICE_ID);
const int ret = XFir_CfgInitialize( &fir, config);
Xil_AssertNonvoid( ret == XST_SUCCESS );
XFir_DisableAutoRestart(&fir);
while(1)
{
const char c = inbyte();
if(XFir_IsIdle(&fir))
{
XFir_Set_input_r(&fir, c);
XFir_Start(&fir);
while(!XFir_IsDone(&fir));
const uint8_t val = XFir_Get_output_r(&fir);
outbyte(val);
}
}
cleanup_platform();
return 0;
}