SSB_HighSpeed_Modem/hsmodem/hsmodem.h

232 lines
6.1 KiB
C
Raw Normal View History

2020-11-14 19:32:47 -05:00
#pragma once
2020-11-05 13:11:57 -05:00
#ifdef _WIN32
#define _WIN32_
// ignore senseless warnings invented by M$ to confuse developers
#pragma warning( disable : 4091 )
#pragma warning( disable : 4003 )
#else
#define _LINUX_
#endif
#include <stdio.h>
#include <ctype.h>
#include <string.h>
#include <errno.h>
#include <sys/types.h>
#include <fcntl.h>
#include <signal.h>
#include <stdlib.h>
#include <stdarg.h>
#include <stdint.h>
#include <wchar.h>
#ifdef _WIN32_
#include "Winsock2.h"
#include "io.h"
#include <Windows.h>
#include <iostream>
#include <process.h>
#include <Tlhelp32.h>
#include <winbase.h>
#include <Shlobj.h>
#define _USE_MATH_DEFINES
#include <math.h>
#pragma comment(lib, "bass.lib")
2020-11-07 12:07:55 -05:00
#pragma comment(lib, "basswasapi.lib")
2020-11-05 13:11:57 -05:00
#pragma comment(lib, "libliquid.lib")
#pragma comment(lib, "fftw_lib/libfftw3-3.lib")
2020-11-21 13:54:47 -05:00
#pragma comment(lib, "opus.lib")
#pragma comment(lib, "libcodec2.lib")
2020-11-05 13:11:57 -05:00
#endif
#ifdef _LINUX_
#include <sys/socket.h>
#include <unistd.h>
#include <sys/time.h>
#include <sys/ioctl.h>
#include <termios.h>
#include <sys/file.h>
#include <pthread.h>
#include <netinet/in.h>
#include <netdb.h>
#include <arpa/inet.h>
#include <pwd.h>
#include <math.h>
#endif
2020-11-27 13:31:22 -05:00
#include "opus.h"
2020-11-05 13:11:57 -05:00
#include "bass.h"
2020-11-07 12:07:55 -05:00
#include "basswasapi.h"
2020-11-05 13:11:57 -05:00
#include "liquid.h"
#include "frameformat.h"
#include "fec.h"
#include "udp.h"
2020-11-14 19:32:47 -05:00
#include "symboltracker.h"
2020-11-21 13:54:47 -05:00
#include "bassenc_opus.h"
#include "codec2.h"
2020-11-05 13:11:57 -05:00
#define jpg_tempfilename "rxdata.jpg"
#define CRC16TX 0
#define CRC16RX 1
#define CRC16FILE 2
2020-11-07 12:07:55 -05:00
// definitions for audio
#define MAXDEVSTRLEN 2000
#define CHANNELS 1 // no of channels used
2020-11-21 13:54:47 -05:00
// voice audio sampling rate
#define VOICE_SAMPRATE 48000 // do NOT change, OPUS works with 48k only
enum _VOICEMODES_ {
VOICEMODE_OFF,
VOICEMODE_LISTENAUDIOIN,
VOICEMODE_INTERNALLOOP,
VOICEMODE_CODECLOOP,
VOICEMODE_DV_FULLDUPLEX,
VOICEMODE_DV_RXONLY
};
2020-11-05 13:11:57 -05:00
void init_packer();
uint8_t* Pack(uint8_t* payload, int type, int status, int* plen);
uint8_t* unpack_data(uint8_t* rxd, int len);
void convertBytesToSyms_QPSK(uint8_t* bytes, uint8_t* syms, int bytenum);
void convertBytesToSyms_8PSK(uint8_t* bytes, uint8_t* syms, int bytenum);
uint8_t* convertQPSKSymToBytes(uint8_t* rxsymbols);
uint8_t* convert8PSKSymToBytes(uint8_t* rxsymbols, int len);
void rotateQPSKsyms(uint8_t* src, uint8_t* dst, int len);
void rotate8PSKsyms(uint8_t* src, uint8_t* dst, int len);
void rotate8APSKsyms(uint8_t* src, uint8_t* dst, int len);
uint8_t* rotateBackQPSK(uint8_t* buf, int len, int rotations);
uint8_t* rotateBack8PSK(uint8_t* buf, int len, int rotations);
uint8_t* rotateBack8APSK(uint8_t* buf, int len, int rotations);
void TX_Scramble(uint8_t* data, int len);
uint8_t* RX_Scramble(uint8_t* data, int len);
uint16_t Crc16_messagecalc(int rxtx, uint8_t* data, int len);
2020-11-21 13:54:47 -05:00
void showbytestring(char* title, uint8_t* data, int totallen, int anz);
2020-11-07 12:07:55 -05:00
void measure_speed_syms(int len);
void measure_speed_bps(int len);
2020-11-05 13:11:57 -05:00
void initFEC();
void GetFEC(uint8_t* txblock, int len, uint8_t* destArray);
int cfec_Reconstruct(uint8_t* darr, uint8_t* destination);
int init_audio(int pbdev, int capdev);
int pb_fifo_freespace(int nolock);
2020-11-21 13:54:47 -05:00
int pb_fifo_usedspace();
2020-11-05 13:11:57 -05:00
void pb_write_fifo_clear();
void pb_write_fifo(float sample);
int cap_read_fifo(float* data);
uint8_t* getAudioDevicelist(int* len);
2020-11-07 12:07:55 -05:00
void setPBvolume(int v);
void setCAPvolume(int v);
void setVolume(int pbcap, int v);
2020-11-21 13:54:47 -05:00
void setVolume_voice(int pbcap, int v);
2020-11-07 12:07:55 -05:00
int init_wasapi(int pbdev, int capdev);
2020-11-09 20:23:21 -05:00
void sendAnnouncement();
2020-11-21 13:54:47 -05:00
void readAudioDevices();
void clear_audio_fifos();
void clear_voice_fifos();
2020-11-05 13:11:57 -05:00
void sleep_ms(int ms);
2020-11-21 13:54:47 -05:00
int getus();
2020-11-05 13:11:57 -05:00
void GRdata_rxdata(uint8_t* pdata, int len, struct sockaddr_in* rxsock);
2020-11-21 13:54:47 -05:00
void toGR_sendData(uint8_t* data, int type, int status);
2020-11-05 13:11:57 -05:00
void modulator(uint8_t sym_in);
2020-11-07 12:07:55 -05:00
int pb_fifo_usedBlocks();
2020-11-05 13:11:57 -05:00
void init_dsp();
int demodulator();
void sendToModulator(uint8_t* d, int len);
void resetModem();
void close_dsp();
void init_fft();
void exit_fft();
void showbytestringf(char* title, float* data, int anz);
uint16_t* make_waterfall(float fre, int* retlen);
2020-11-21 13:54:47 -05:00
int init_audio_voice(int setpbdev, int setcapdev);
void pb_write_fifo_voice(float sample);
int cap_read_fifo_voice(float* data);
void toVoice(float sample);
void toCodecDecoder(uint8_t* pdata, int len);
void init_voiceproc();
void encode(float f);
int init_wasapi_voice(int pbdev, int capdev);
void init_codec2();
void encode_codec2(float f);
void toCodecDecoder_codec2(uint8_t* pdata, int len);
void close_wasapi();
void close_wasapi_voice();
void closeAllandTerminate();
void close_voiceproc();
void close_codec2();
void close_audio();
void close_audio_voice();
int cap_fifo_usedPercent();
2020-11-14 19:32:47 -05:00
void km_symtrack_cccf_create(int _ftype,
unsigned int _k,
unsigned int _m,
float _beta,
int _ms);
void km_symtrack_cccf_reset(int mode);
void km_symtrack_cccf_set_bandwidth(float _bw);
void km_symtrack_execute(liquid_float_complex _x, liquid_float_complex* _y, unsigned int* _ny, unsigned int* psym_out);
2020-11-05 13:11:57 -05:00
extern int speedmode;
extern int bitsPerSymbol;
extern int constellationSize;
extern int speed;
extern int keeprunning;
extern int caprate;
extern int BC_sock_AppToModem;
2020-11-21 13:54:47 -05:00
extern int DATA_sock_AppToModem;
2020-11-05 13:11:57 -05:00
extern int UdpDataPort_ModemToApp;
extern int txinterpolfactor;
extern int rxPreInterpolfactor;
extern char appIP[20];
2020-11-07 12:07:55 -05:00
extern float softwareCAPvolume;
2020-11-21 13:54:47 -05:00
extern float softwareCAPvolume_voice;
2020-11-09 20:23:21 -05:00
extern int announcement;
extern int ann_running;
extern int transmissions;
extern int linespeed;
2020-11-14 19:32:47 -05:00
extern uint8_t maxLevel;
2020-11-21 13:54:47 -05:00
extern int VoiceAudioMode;
extern int opusbitrate;
extern int init_audio_result;
extern int init_voice_result;
extern int initialLSvol;
extern int initialMICvol;
extern int codec;
2020-11-24 10:07:52 -05:00
extern int trigger_resetmodem;
extern int rxlevel_deteced;
extern int rx_in_sync;
2020-11-21 13:54:47 -05:00
// audio device description table
typedef struct {
int bassdev; // bass (basswasapi) dev no
char name[256]; // DEV name
char id[256];
} AUDIODEVS;
2020-11-05 13:11:57 -05:00
#ifdef _LINUX_
int isRunning(char* prgname);
void install_signal_handler();
int isRunning(char* prgname);
#endif