Harald Welte | faea754 | 2016-12-24 01:21:03 +0100 | [diff] [blame] | 1 | #include <stdio.h> |
| 2 | |
| 3 | #include "diag_log.h" |
| 4 | #include "diag_gsm.h" |
| 5 | #include "log_codes_gsm.h" |
| 6 | |
| 7 | |
| 8 | static void handle_rr_sig_msg(struct log_hdr *lh, struct msgb *msg) |
| 9 | { |
| 10 | struct diag_gsm_rr_msg *rm = (struct diag_gsm_rr_msg *) msgb_data(msg); |
| 11 | |
| 12 | printf("RR: %02x %02x %u: %s\n", rm->chan_type, rm->msg_type, |
| 13 | rm->length, osmo_hexdump(msgb_data(msg), rm->length)); |
| 14 | } |
| 15 | |
| 16 | static void handle_rr_state_msg(struct log_hdr *lh, struct msgb *msg) |
| 17 | { |
| 18 | struct diag_gsm_rr_state *rrs = (struct diag_gsm_rr_state *) msgb_data(msg); |
| 19 | printf("RR-STATE { state=%s, substate=%u, status=%u, mode=%u }\n", |
| 20 | get_value_string(diag_gsm_rr_st_vals, rrs->state) |
| 21 | , rrs->substate, rrs->status, rrs->mode); |
| 22 | |
| 23 | } |
| 24 | |
| 25 | static const struct diag_log_dispatch_tbl log_tbl[] = { |
| 26 | { GSM(LOG_GSM_RR_SIGNALING_MESSAGE_C), handle_rr_sig_msg }, |
| 27 | { GSM(LOG_GSM_RR_STATE_C), handle_rr_state_msg }, |
| 28 | }; |
| 29 | |
| 30 | static __attribute__((constructor)) void on_dso_load_gsm(void) |
| 31 | { |
| 32 | diag_log_reg_dispatch(log_tbl, ARRAY_SIZE(log_tbl)); |
| 33 | } |