diff options
author | Harald Welte <laforge@gnumonks.org> | 2018-05-16 20:15:09 +0200 |
---|---|---|
committer | Harald Welte <laforge@gnumonks.org> | 2018-05-16 20:15:09 +0200 |
commit | a3ddfb1eff302173ff9891e68c9f8576e5f175f0 (patch) | |
tree | 074dda18037b37dfb2e04826a4a26e9950e54774 /src/e1_test.c | |
parent | f01471d212b908ff8c63ce1c9d2c46ca60429177 (diff) | |
parent | 24531cebef537ebf87c373033538bdfaf167b89f (diff) |
Merge branch 'laforge/software'
Diffstat (limited to 'src/e1_test.c')
-rw-r--r-- | src/e1_test.c | 141 |
1 files changed, 141 insertions, 0 deletions
diff --git a/src/e1_test.c b/src/e1_test.c new file mode 100644 index 0000000..cd0bf87 --- /dev/null +++ b/src/e1_test.c @@ -0,0 +1,141 @@ +#include <stdint.h> +#include <unistd.h> +#include <errno.h> +#include <stdio.h> +#include <string.h> + +#include <osmocom/core/utils.h> +#include <osmocom/core/logging.h> +#include <osmocom/core/application.h> +#include <osmocom/gsm/gsm_utils.h> + +#include "osmo_e1f.h" + +static struct osmo_e1f_instance inst; +static struct log_info log_info = {}; + +/* pull data out of the transmitter and print hexdumps */ +static void pull_and_print(struct osmo_e1f_instance *e1i) +{ + uint8_t buf[32]; + osmo_e1f_pull_tx_frame(e1i, buf); + printf("%s\n", osmo_hexdump(buf, sizeof(buf))); +} + +static void data_cb(struct osmo_e1f_instance_ts *e1t, struct msgb *msg) +{ + printf("Rx TS %u: %s\n", e1t->ts_nr, msgb_hexdump(msg)); + msgb_free(msg); +} + +static void notify_cb(struct osmo_e1f_instance *e1i, enum osmo_e1f_notify_event evt, + bool present, void *data) +{ + printf("NOTIFY: %s %s\n", osmo_e1f_notify_event_name(evt), present ? "PRESENT" : "ABSENT"); +} + +/* feed some random data into the E1 instance */ +static void tc_rx_random() +{ + uint8_t buf[32]; + int i; + + for (i = 0; i < 200; i++) { + osmo_get_rand_id(buf, sizeof(buf)); + osmo_e1f_rx_frame(&inst, buf); + } +} + +static void tc_rx_align_basic() +{ + uint8_t buf[32]; + int i; + + for (i = 0; i < 80; i++) { + memset(buf, 0xff, sizeof(buf)); + switch (i %2) { + case 0: + buf[0] = 0x9B; + break; + case 1: + buf[0] = 0x40; + break; + } + osmo_e1f_rx_frame(&inst, buf); + } +} + +static void tc_rx_align_mframe() +{ + uint8_t buf[32]; + int i; + + for (i = 0; i < 80; i++) { + memset(buf, 0xff, sizeof(buf)); + switch (i % 16) { + case 0: + case 2: + case 4: + case 6: + case 8: + case 10: + case 12: + case 14: + buf[0] = 0x9B; + break; + case 1: + case 3: + case 7: + case 13: + case 15: + buf[0] = 0x40; + break; + case 5: + case 9: + case 11: + buf[0] = 0xc0; + break; + } + osmo_e1f_rx_frame(&inst, buf); + } +} + + +static void tc_tx_idle() +{ + int i; + for (i = 0; i < 20; i++) { + pull_and_print(&inst); + } +} + +int main(int argc, char **argv) +{ + int i; + + osmo_init_logging2(NULL, &log_info); + osmo_e1f_init(); + + osmo_e1f_instance_init(&inst, "e1_test", ¬ify_cb, true, NULL); + for (i = 1; i < 32; i++) { + struct osmo_e1f_instance_ts *e1t = osmo_e1f_instance_ts(&inst, i); + osmo_e1f_ts_config(e1t, &data_cb, 40, true, OSMO_E1F_TS_RAW); + } + + printf("\nRx Random...\n"); + osmo_e1f_instance_reset(&inst); + tc_rx_random(); + + printf("\nAlign (Basic)...\n"); + osmo_e1f_instance_reset(&inst); + tc_rx_align_basic(); + + printf("\nAlign (Mframe)...\n"); + osmo_e1f_instance_reset(&inst); + tc_rx_align_mframe(); + + printf("\nTX Idle...\n"); + osmo_e1f_instance_reset(&inst); + tc_tx_idle(); + +} |