blob: 7a52b055a935572a196c36aced802c134acbdfbc [file] [log] [blame]
rpp4f0f3b52015-06-10 10:23:30 +02001/* -*- c++ -*- */
2/* @file
3 * @author Piotr Krysik <ptrkrysik@gmail.com>
4 * @section LICENSE
5 *
6 * Gr-gsm is free software; you can redistribute it and/or modify
7 * it under the terms of the GNU General Public License as published by
8 * the Free Software Foundation; either version 3, or (at your option)
9 * any later version.
10 *
11 * Gr-gsm is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 * GNU General Public License for more details.
15 *
16 * You should have received a copy of the GNU General Public License
17 * along with gr-gsm; see the file COPYING. If not, write to
18 * the Free Software Foundation, Inc., 51 Franklin Street,
19 * Boston, MA 02110-1301, USA.
20 *
21 */
22
23#ifndef INCLUDED_GSM_CX_CHANNEL_HOPPER_IMPL_H
24#define INCLUDED_GSM_CX_CHANNEL_HOPPER_IMPL_H
25
26#include <grgsm/receiver/cx_channel_hopper.h>
27
28namespace gr {
29 namespace gsm {
30
31 class cx_channel_hopper_impl : public cx_channel_hopper
32 {
33 private:
rpp267214a2015-06-10 11:49:55 +020034 std::vector<int> d_ma; // Mobile Allocation list. Contains all channels that are used while channel hopping
35 int d_maio; // Mobile Allocation Index Offset
36 int d_hsn; // Hopping Sequence Number
37 int d_narfcn; // Length of d_ma
38
39 int calculate_ma_sfh(int maio, int hsn, int n, int fn);
40 void assemble_bursts(pmt::pmt_t msg);
rpp4f0f3b52015-06-10 10:23:30 +020041
42 public:
rpp267214a2015-06-10 11:49:55 +020043 cx_channel_hopper_impl(const std::vector<int> &ma, int maio, int hsn);
rpp4f0f3b52015-06-10 10:23:30 +020044 ~cx_channel_hopper_impl();
45 };
46
47 } // namespace gsm
48} // namespace gr
49
50#endif /* INCLUDED_GSM_CX_CHANNEL_HOPPER_IMPL_H */
51