forked from E3V3A/gsm-parser
-
Notifications
You must be signed in to change notification settings - Fork 0
/
gsm_interleave.c
52 lines (43 loc) · 924 Bytes
/
gsm_interleave.c
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
43
44
45
46
47
48
49
50
51
#include "gsm_interleave.h"
static unsigned _sacch_map[456];
static unsigned _facch_map[456];
void gsm_interleave_init()
{
int j, k, B;
/* sacch map */
for (k = 0; k < 456; k++) {
B = k % 4;
j = 2 * ((49 * k) % 57) + ((k % 8) / 4);
_sacch_map[k] = B * 114 + j;
}
/* facch map */
for (k = 0; k < 456; k++) {
B = k % 8;
j = 2 * ((49 * k) % 57) + ((k % 8) / 4);
_facch_map[k] = B * 114 + j;
}
}
void gsm_inter_sacch(const uint8_t *src, uint8_t *dst)
{
int k;
for (k = 0; k < 456; k++)
dst[_sacch_map[k]] = src[k];
}
void gsm_deinter_sacch(const uint8_t *src, uint8_t *dst)
{
int k;
for (k = 0; k < 456; k++)
dst[k] = src[_sacch_map[k]];
}
void gsm_inter_facch(const uint8_t *src, uint8_t *dst)
{
int k;
for (k = 0; k < 456; k++)
dst[_facch_map[k]] = src[k];
}
void gsm_deinter_facch(const uint8_t *src, uint8_t *dst)
{
int k;
for (k = 0; k < 456; k++)
dst[k] = src[_facch_map[k]];
}