| 
									
										
										
										
											2023-11-18 06:36:53 +01:00
										 |  |  | ///////////////////////////////////////////////////////////////////////////////////////
 | 
					
						
							|  |  |  | // Copyright (C) 2021-2022 Jon Beniston, M7RCE <jon@beniston.com>                    //
 | 
					
						
							|  |  |  | //                                                                                   //
 | 
					
						
							|  |  |  | // This program is free software; you can redistribute it and/or modify              //
 | 
					
						
							|  |  |  | // it under the terms of the GNU General Public License as published by              //
 | 
					
						
							|  |  |  | // the Free Software Foundation as version 3 of the License, or                      //
 | 
					
						
							|  |  |  | // (at your option) any later version.                                               //
 | 
					
						
							|  |  |  | //                                                                                   //
 | 
					
						
							|  |  |  | // This program is distributed in the hope that it will be useful,                   //
 | 
					
						
							|  |  |  | // but WITHOUT ANY WARRANTY; without even the implied warranty of                    //
 | 
					
						
							|  |  |  | // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the                      //
 | 
					
						
							|  |  |  | // GNU General Public License V3 for more details.                                   //
 | 
					
						
							|  |  |  | //                                                                                   //
 | 
					
						
							|  |  |  | // You should have received a copy of the GNU General Public License                 //
 | 
					
						
							|  |  |  | // along with this program. If not, see <http://www.gnu.org/licenses/>.              //
 | 
					
						
							|  |  |  | ///////////////////////////////////////////////////////////////////////////////////////
 | 
					
						
							| 
									
										
										
										
											2021-03-31 16:41:42 +01:00
										 |  |  | #ifndef DVB2_H
 | 
					
						
							|  |  |  | #define DVB2_H
 | 
					
						
							|  |  |  | #include <queue>
 | 
					
						
							|  |  |  | #include <deque>
 | 
					
						
							|  |  |  | #include <list>
 | 
					
						
							|  |  |  | #include <stdio.h>
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | typedef unsigned int u32; | 
					
						
							|  |  |  | typedef unsigned char u8; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-07-10 22:37:52 +02:00
										 |  |  | // BB HEADER fields
 | 
					
						
							| 
									
										
										
										
											2021-03-31 16:41:42 +01:00
										 |  |  | #define TS_GS_TRANSPORT 3
 | 
					
						
							|  |  |  | #define TS_GS_GENERIC_PACKETIZED 0
 | 
					
						
							|  |  |  | #define TS_GS_GENERIC_CONTINUOUS 1
 | 
					
						
							|  |  |  | #define TS_GS_RESERVED 2
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define SIS_MIS_SINGLE 1
 | 
					
						
							|  |  |  | #define SIS_MIS_MULTIPLE 0
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define CCM 1
 | 
					
						
							|  |  |  | #define ACM 0
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define ISSYI_ACTIVE 1
 | 
					
						
							|  |  |  | #define ISSYI_NOT_ACTIVE 0
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define NPD_ACTIVE 1
 | 
					
						
							|  |  |  | #define NPD_NOT_ACTIVE 0
 | 
					
						
							|  |  |  | // Rolloff
 | 
					
						
							|  |  |  | #define RO_0_35 0
 | 
					
						
							|  |  |  | #define RO_0_25 1
 | 
					
						
							|  |  |  | #define RO_0_20 2
 | 
					
						
							|  |  |  | #define RO_RESERVED 3
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // Pilots
 | 
					
						
							|  |  |  | #define PILOTS_OFF 0
 | 
					
						
							|  |  |  | #define PILOTS_ON 1
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | typedef struct{ | 
					
						
							|  |  |  |     int ts_gs; | 
					
						
							|  |  |  |     int sis_mis; | 
					
						
							|  |  |  |     int ccm_acm; | 
					
						
							|  |  |  |     int issyi; | 
					
						
							|  |  |  |     int npd; | 
					
						
							|  |  |  |     int ro; | 
					
						
							|  |  |  |     int isi; | 
					
						
							|  |  |  |     int upl; | 
					
						
							|  |  |  |     int dfl; | 
					
						
							|  |  |  |     int sync; | 
					
						
							|  |  |  |         int syncd; | 
					
						
							|  |  |  | }BBHeader; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | typedef int Bit; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-07-10 22:37:52 +02:00
										 |  |  | // The number of usable and stuff bits in a frame
 | 
					
						
							| 
									
										
										
										
											2021-03-31 16:41:42 +01:00
										 |  |  | typedef struct{ | 
					
						
							|  |  |  |     int data_bits; | 
					
						
							|  |  |  |     int stuff_bits; | 
					
						
							|  |  |  | }FrameBits; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define FRAME_SIZE_NORMAL 64800
 | 
					
						
							|  |  |  | #define FRAME_SIZE_SHORT  16200
 | 
					
						
							|  |  |  | #define LDPC_ENCODE_TABLE_LENGTH (FRAME_SIZE_NORMAL*10)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | typedef struct{ | 
					
						
							|  |  |  |     int table_length; | 
					
						
							|  |  |  |     Bit d[LDPC_ENCODE_TABLE_LENGTH]; | 
					
						
							|  |  |  |     Bit p[LDPC_ENCODE_TABLE_LENGTH]; | 
					
						
							|  |  |  | }Ldpc_encode_table; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define FRAME_NORMAL 0x00
 | 
					
						
							|  |  |  | #define FRAME_SHORT  0x10
 | 
					
						
							|  |  |  | #define BB_HEADER_LENGTH_BITS 72
 | 
					
						
							|  |  |  | #define CRC8_LENGTH_BITS 8
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define PADDING_LENGTH 200
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // Code rates
 | 
					
						
							|  |  |  | #define CR_1_4 0
 | 
					
						
							|  |  |  | #define CR_1_3 1
 | 
					
						
							|  |  |  | #define CR_2_5 2
 | 
					
						
							|  |  |  | #define CR_1_2 3
 | 
					
						
							|  |  |  | #define CR_3_5 4
 | 
					
						
							|  |  |  | #define CR_2_3 5
 | 
					
						
							|  |  |  | #define CR_3_4 6
 | 
					
						
							|  |  |  | #define CR_4_5 7
 | 
					
						
							|  |  |  | #define CR_5_6 8
 | 
					
						
							|  |  |  | #define CR_8_9 9
 | 
					
						
							|  |  |  | #define CR_9_10 10
 | 
					
						
							|  |  |  | // BCH Code
 | 
					
						
							|  |  |  | #define BCH_CODE_N8  0
 | 
					
						
							|  |  |  | #define BCH_CODE_N10 1
 | 
					
						
							|  |  |  | #define BCH_CODE_N12 2
 | 
					
						
							|  |  |  | #define BCH_CODE_S12 3
 | 
					
						
							|  |  |  | // Constellation
 | 
					
						
							|  |  |  | #define M_QPSK   0
 | 
					
						
							|  |  |  | #define M_8PSK   1
 | 
					
						
							|  |  |  | #define M_16APSK 2
 | 
					
						
							|  |  |  | #define M_32APSK 3
 | 
					
						
							|  |  |  | //Interface
 | 
					
						
							|  |  |  | #define M_ACM 0
 | 
					
						
							|  |  |  | #define M_CCM 1
 | 
					
						
							|  |  |  | #define M_VCM 2
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | typedef struct{ | 
					
						
							|  |  |  |    int frame_type; | 
					
						
							|  |  |  |    int code_rate; | 
					
						
							|  |  |  |    int roll_off; | 
					
						
							|  |  |  |    int constellation; | 
					
						
							|  |  |  |    int pilots; | 
					
						
							|  |  |  |    int dummy_frame; | 
					
						
							|  |  |  |    int null_deletion; | 
					
						
							|  |  |  |    int intface; | 
					
						
							|  |  |  |    int broadcasting; | 
					
						
							|  |  |  |    // Calculated information, not used by caller
 | 
					
						
							|  |  |  |    BBHeader bb_header; | 
					
						
							|  |  |  |    int kldpc; | 
					
						
							|  |  |  |    int kbch; | 
					
						
							|  |  |  |    int nldpc; | 
					
						
							|  |  |  |    int q_val; | 
					
						
							|  |  |  |    int bch_code; | 
					
						
							|  |  |  |    int useable_data_bits; | 
					
						
							|  |  |  |    int padding_bits; | 
					
						
							|  |  |  |    int total_bits; | 
					
						
							|  |  |  |    int nr_tps; | 
					
						
							|  |  |  |    int nr_tps_bits; | 
					
						
							|  |  |  | }DVB2FrameFormat; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | class DVB2{ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | public: | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | protected: | 
					
						
							|  |  |  |     Bit m_frame[FRAME_SIZE_NORMAL]; | 
					
						
							|  |  |  |     DVB2FrameFormat m_format[2]; | 
					
						
							|  |  |  |     Bit m_padding[PADDING_LENGTH]; | 
					
						
							|  |  |  |         int m_frame_offset_bits; | 
					
						
							|  |  |  |         int m_params_changed; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | private: | 
					
						
							|  |  |  |     int m_bbheader[BB_HEADER_LENGTH_BITS+CRC8_LENGTH_BITS]; | 
					
						
							|  |  |  |     int m_bb_randomise[FRAME_SIZE_NORMAL]; | 
					
						
							|  |  |  |     u32 m_poly_n_8[4]; | 
					
						
							|  |  |  |     u32 m_poly_n_10[5]; | 
					
						
							|  |  |  |     u32 m_poly_n_12[6]; | 
					
						
							|  |  |  |     u32 m_poly_s_12[6]; | 
					
						
							|  |  |  |     u8  m_crc_tab[256]; | 
					
						
							|  |  |  |     u8  m_dnp; // Deleted null packet
 | 
					
						
							|  |  |  |     // Transport packet queue
 | 
					
						
							| 
									
										
										
										
											2022-09-08 16:13:43 +01:00
										 |  |  |     std::queue <u8> m_tp_q; | 
					
						
							| 
									
										
										
										
											2021-03-31 16:41:42 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     // LDPC tables
 | 
					
						
							|  |  |  |     const static int ldpc_tab_1_4N[45][13]; | 
					
						
							|  |  |  |     const static int ldpc_tab_1_3N[60][13]; | 
					
						
							|  |  |  |     const static int ldpc_tab_2_5N[72][13]; | 
					
						
							|  |  |  |     const static int ldpc_tab_1_2N[90][9]; | 
					
						
							|  |  |  |     const static int ldpc_tab_3_5N[108][13]; | 
					
						
							|  |  |  |     const static int ldpc_tab_2_3N[120][14]; | 
					
						
							|  |  |  |     const static int ldpc_tab_3_4N[135][13]; | 
					
						
							|  |  |  |     const static int ldpc_tab_4_5N[144][12]; | 
					
						
							|  |  |  |     const static int ldpc_tab_5_6N[150][14]; | 
					
						
							|  |  |  |     const static int ldpc_tab_8_9N[160][5]; | 
					
						
							|  |  |  |     const static int ldpc_tab_9_10N[162][5]; | 
					
						
							|  |  |  |     const static int ldpc_tab_1_4S[9][13]; | 
					
						
							|  |  |  |     const static int ldpc_tab_1_3S[15][13]; | 
					
						
							|  |  |  |     const static int ldpc_tab_2_5S[18][13]; | 
					
						
							|  |  |  |     const static int ldpc_tab_1_2S[20][9]; | 
					
						
							|  |  |  |     const static int ldpc_tab_3_5S[27][13]; | 
					
						
							|  |  |  |     const static int ldpc_tab_2_3S[30][14]; | 
					
						
							|  |  |  |     const static int ldpc_tab_3_4S[33][13]; | 
					
						
							|  |  |  |     const static int ldpc_tab_4_5S[35][4]; | 
					
						
							|  |  |  |     const static int ldpc_tab_5_6S[37][14]; | 
					
						
							|  |  |  |     const static int ldpc_tab_8_9S[40][5]; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     Ldpc_encode_table m_ldpc_encode; | 
					
						
							|  |  |  |     void bb_randomise(void); | 
					
						
							|  |  |  |     void init_scrambler(void); | 
					
						
							|  |  |  |     void init_bb_randomiser(void); | 
					
						
							|  |  |  |     void ldpc_lookup_generate(void); | 
					
						
							|  |  |  |     void ldpc_encode( void ); | 
					
						
							|  |  |  |     int add_transport_packet( u8 *pkt, Bit *b ); | 
					
						
							|  |  |  |     void build_crc8_table( void ); | 
					
						
							|  |  |  |     u8   calc_crc8( u8 *b, int len ); | 
					
						
							|  |  |  |     int add_crc8_bits( Bit *in, int length ); | 
					
						
							|  |  |  |     void unpack_transport_packet_add_crc( u8 *ts ); | 
					
						
							|  |  |  |     void add_bbheader( void ); | 
					
						
							|  |  |  |     void poly_reverse( int *pin, int *pout, int len ); | 
					
						
							|  |  |  |     void poly_pack( const int *pin, u32* pout, int len ); | 
					
						
							|  |  |  |     int poly_mult( const int *ina, int lena, const int *inb, int lenb, int *out ); | 
					
						
							|  |  |  |     void bch_poly_build_tables( void ); | 
					
						
							|  |  |  |     void reg_4_shift( u32 *sr ); | 
					
						
							|  |  |  |     void reg_5_shift( u32 *sr ); | 
					
						
							|  |  |  |     void reg_6_shift( u32 *sr ); | 
					
						
							|  |  |  |     Bit bch_n_8_encode(  Bit *in, int len ); | 
					
						
							|  |  |  |     Bit bch_n_10_encode( Bit *in, int len ); | 
					
						
							|  |  |  |     Bit bch_n_12_encode( Bit *in, int len ); | 
					
						
							|  |  |  |     Bit bch_s_12_encode( Bit *in, int len ); | 
					
						
							|  |  |  |     int bch_encode( void ); | 
					
						
							|  |  |  |     int add_ts_frame_base( u8 *ts ); | 
					
						
							|  |  |  |     void ldpc_encode_test(); | 
					
						
							|  |  |  |     void base_end_of_frame_actions(void); | 
					
						
							|  |  |  | protected: | 
					
						
							|  |  |  |     int  set_configure( DVB2FrameFormat *f ); | 
					
						
							|  |  |  |     void get_configure( DVB2FrameFormat *f ); | 
					
						
							|  |  |  |     int  next_ts_frame_base( u8 *ts ); | 
					
						
							|  |  |  | public: | 
					
						
							|  |  |  |     // encode a new transport packet
 | 
					
						
							|  |  |  | //    virtual void physical(void);
 | 
					
						
							|  |  |  |     DVB2(); | 
					
						
							|  |  |  |     ~DVB2(); | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #endif
 |