root / lab2 / lab2.c @ 27
History | View | Annotate | Download (2.45 KB)
1 |
#include <lcom/lcf.h> |
---|---|
2 |
#include <lcom/lab2.h> |
3 |
|
4 |
#include <stdbool.h> |
5 |
#include <stdint.h> |
6 |
|
7 |
int main(int argc, char *argv[]) { |
8 |
// sets the language of LCF messages (can be either EN-US or PT-PT)
|
9 |
lcf_set_language("EN-US");
|
10 |
|
11 |
// enables to log function invocations that are being "wrapped" by LCF
|
12 |
// [comment this out if you don't want/need it]
|
13 |
lcf_trace_calls("/home/lcom/labs/lab2/trace.txt");
|
14 |
|
15 |
// enables to save the output of printf function calls on a file
|
16 |
// [comment this out if you don't want/need it]
|
17 |
lcf_log_output("/home/lcom/labs/lab2/output.txt");
|
18 |
|
19 |
// handles control over to LCF
|
20 |
// [LCF handles command line arguments and invokes the right function]
|
21 |
if (lcf_start(argc, argv))
|
22 |
return 1; |
23 |
|
24 |
// LCF clean up tasks
|
25 |
// [must be the last statement before return]
|
26 |
lcf_cleanup(); |
27 |
|
28 |
return 0; |
29 |
} |
30 |
|
31 |
int(timer_test_read_config)(uint8_t timer, enum timer_status_field field){ |
32 |
uint8_t state = 0;
|
33 |
if(timer_get_conf(timer, &state)) return 1; |
34 |
if(timer_display_conf(timer, state, field)) return 1; |
35 |
return 0; |
36 |
} |
37 |
|
38 |
int(timer_test_time_base)(uint8_t timer, uint32_t freq) {
|
39 |
if (timer_set_frequency(timer, freq)) return 1; |
40 |
return 0; |
41 |
} |
42 |
|
43 |
extern int no_interrupts; |
44 |
|
45 |
int(timer_test_int)(uint8_t time) {
|
46 |
const uint32_t frequency = 60; // Frequency asummed at 60Hz |
47 |
int ipc_status, r;
|
48 |
message msg; |
49 |
uint8_t hook = 0;
|
50 |
no_interrupts = 0;
|
51 |
timer_subscribe_int(&hook); |
52 |
int irq_set = BIT(hook);
|
53 |
while (time) {
|
54 |
/* Get a request message. */
|
55 |
if ((r = driver_receive(ANY, &msg, &ipc_status)) != 0) { |
56 |
printf("driver_receive failed with %d", r);
|
57 |
continue;
|
58 |
} |
59 |
if (is_ipc_notify(ipc_status)) { /* received notification */ |
60 |
switch (_ENDPOINT_P(msg.m_source)) {
|
61 |
case HARDWARE: /* hardware interrupt notification */ |
62 |
if (msg.m_notify.interrupts & irq_set) { /* subscribed interrupt */ |
63 |
timer_int_handler(); |
64 |
if (!(no_interrupts % frequency)) {
|
65 |
timer_print_elapsed_time(); |
66 |
time--; |
67 |
} |
68 |
} |
69 |
break;
|
70 |
default:
|
71 |
break; /* no other notifications expected: do nothing */ |
72 |
} |
73 |
} else { /* received standart message, not a notification */ |
74 |
/* no standart message expected: do nothing */
|
75 |
} |
76 |
} |
77 |
timer_unsubscribe_int(); |
78 |
return 0; |
79 |
} |