Add a simple DVBS modulator- output GPIO 12

v2beta
F5OEO 2018-09-03 13:56:34 +00:00
rodzic e6c11a1521
commit 66f1178486
5 zmienionych plików z 4275 dodań i 12 usunięć

Wyświetl plik

@ -1,41 +1,47 @@
#all: ../rpitx ../pissb ../pisstv ../pifsq ../pifm ../piam ../pidcf77
all: ../pisstv ../piopera ../pifsq ../pichirp ../sendiq ../tune ../freedv
all: ../pisstv ../piopera ../pifsq ../pichirp ../sendiq ../tune ../freedv ../dvbrf
CFLAGS = -Wall -g -O2 -Wno-unused-variable
LDFLAGS = librpitx/src/librpitx.a -lm -lrt -lpthread
CC= g++
CCP= g++
CC= gcc
../rpitx: RpiTx.cpp librpitx/src/librpitx.h
$(CC) $(CFLAGS) -o ../rpitx RpiTx.c $(LDFLAGS)
$(CCP) $(CFLAGS) -o ../rpitx RpiTx.c $(LDFLAGS)
CFLAGS_Pissb = -Wall -g -O2 -Wno-unused-variable
LDFLAGS_Pissb = librpitx/src/librpitx.a -lm -lrt -lpthread -lsndfile -lliquid
../pissb: ssbgen/test_ssb.c ssbgen/ssb_gen.c ssbgen/liquid_ssb.c
gcc $(CFLAGS_Pissb) -o ../pissb ssbgen/liquid_ssb.c $(LDFLAGS_Pissb)
$(CC) $(CFLAGS_Pissb) -o ../pissb ssbgen/liquid_ssb.c $(LDFLAGS_Pissb)
../pisstv : sstv/pisstv.cpp
$(CC) $(CFLAGS) -o ../pisstv sstv/pisstv.cpp $(LDFLAGS)
$(CCP) $(CFLAGS) -o ../pisstv sstv/pisstv.cpp $(LDFLAGS)
../piopera : opera/opera.cpp
$(CC) $(CFLAGS) -o ../piopera opera/opera.cpp $(LDFLAGS)
$(CCP) $(CFLAGS) -o ../piopera opera/opera.cpp $(LDFLAGS)
../pifsq : fsq/pifsq.cpp
$(CC) $(CFLAGS) -o ../pifsq fsq/pifsq.cpp $(LDFLAGS)
$(CCP) $(CFLAGS) -o ../pifsq fsq/pifsq.cpp $(LDFLAGS)
../pichirp : chirp/chirp.cpp
$(CC) $(CFLAGS) -o ../pichirp chirp/chirp.cpp $(LDFLAGS)
$(CCP) $(CFLAGS) -o ../pichirp chirp/chirp.cpp $(LDFLAGS)
../sendiq : sendiq.cpp librpitx/src/librpitx.a
$(CC) $(CFLAGS) -o ../sendiq sendiq.cpp $(LDFLAGS)
$(CCP) $(CFLAGS) -o ../sendiq sendiq.cpp $(LDFLAGS)
../tune : tune.cpp
$(CC) $(CFLAGS) -o ../tune tune.cpp $(LDFLAGS)
$(CCP) $(CFLAGS) -o ../tune tune.cpp $(LDFLAGS)
../freedv : freedv/freedv.cpp
$(CC) $(CFLAGS) -o ../freedv freedv/freedv.cpp $(LDFLAGS)
$(CCP) $(CFLAGS) -o ../freedv freedv/freedv.cpp $(LDFLAGS)
../dvbrf : dvb/dvbrf.cpp dvb/dvbsenco8.s dvb/fec100.c librpitx/src/librpitx.a
$(CC) $(CFLAGS) -c -o dvb/dvbsenco8.o dvb/dvbsenco8.s
$(CC) $(CFLAGS) -c -o dvb/fec100.o dvb/fec100.c
$(CCP) $(CFLAGS) -o ../dvbrf dvb/dvbrf.cpp dvb/dvbsenco8.o dvb/fec100.o $(LDFLAGS)
CFLAGS_Pifm = -Wall -g -O2 -Wno-unused-variable
LDFLAGS_Pifm = librpitx/src/librpitx.a -lm -lrt -lpthread -lsndfile
@ -53,7 +59,7 @@ LDFLAGS_Pidcf77 = librpitx/src/librpitx.a -lm -lrt -lpthread
$(CC) $(CFLAGS_Piam) -o ../pidcf77 ../dcf77/pidcf77.c $(LDFLAGS_Piam)
clean:
rm -f ../rpitx ../pissb ../pisstv ../pifsq ../pifm ../piam ../pidcf77 ../pichirp ../tune ../freedv RpiTx.o mailbox.o RpiGpio.o RpiDma.o
rm -f ../dvbrf ../rpitx ../pissb ../pisstv ../pifsq ../pifm ../piam ../pidcf77 ../pichirp ../tune ../freedv RpiTx.o mailbox.o RpiGpio.o RpiDma.o
install: all
install -m 0755 ../pisstv /usr/bin

221
src/dvb/dvbrf.cpp 100644
Wyświetl plik

@ -0,0 +1,221 @@
#include <unistd.h>
#include "../librpitx/src/librpitx.h"
#include "stdio.h"
#include <cstring>
#include <signal.h>
extern "C"
{
#include "fec100.h"
}
extern "C" void dvbsenco_init (void) ;
extern "C" uchar* dvbsenco (uchar*) ;
extern "C" void energy (uchar* input,uchar *output) ;
extern "C" void reed (uchar *input188) ;
extern "C" uchar* interleave (uchar* packetin) ;
bool running=true;
#define PROGRAM_VERSION "0.1"
void SimpleTestFileIQ(uint64_t Freq)
{
}
void print_usage(void)
{
fprintf(stderr,\
"\ndvbrf -%s\n\
Usage:\ndvbrf [-i File Input][-s Samplerate][-l] [-f Frequency] [-h Harmonic number] \n\
-i path to Transport Stream File Input \n\
-s SampleRate 10000-250000 \n\
-c Fec : {1/2,3/4,5/6,7/8} \n\
-f float central frequency Hz(50 kHz to 1500 MHz),\n\
-l loop mode for file input\n\
-h Use harmonic number n\n\
-? help (this help).\n\
\n",\
PROGRAM_VERSION);
} /* end function print_usage */
static void
terminate(int num)
{
if(running)
fprintf(stderr,"Caught signal - Terminating %x\n",num);
running=false;
}
#define MAX_SAMPLERATE 2000000
int main(int argc, char* argv[])
{
int a;
int anyargs = 1;
float SetFrequency=434e6;
int SampleRate=48000;
bool loop_mode_flag=false;
char* FileName=NULL;
int Harmonic=1;
enum {typeiq_i16,typeiq_u8,typeiq_float,typeiq_double};
int InputType=typeiq_i16;
int Decimation=1;
int FEC=-1;
while(1)
{
a = getopt(argc, argv, "i:f:s:h:lt:c:");
if(a == -1)
{
if(anyargs) break;
else a='h'; //print usage and exit
}
anyargs = 1;
switch(a)
{
case 'i': // File name
FileName = optarg;
break;
case 'f': // Frequency
SetFrequency = atof(optarg);
break;
case 's': // SampleRate (Only needeed in IQ mode)
SampleRate = atoi(optarg);
if(SampleRate>MAX_SAMPLERATE)
{
fprintf(stderr,"SampleRate too high : >%d sample/s",MAX_SAMPLERATE);
exit(1);
};
break;
case 'c': // FEC
if(strcmp("1/2",optarg)==0) FEC=1;
if(strcmp("2/3",optarg)==0) FEC=2;
if(strcmp("3/4",optarg)==0) FEC=3;
if(strcmp("5/6",optarg)==0) FEC=5;
if(strcmp("7/8",optarg)==0) FEC=7;
if(strcmp("carrier",optarg)==0) {fprintf(stderr,"Carrier mode\n");FEC=0;}//CARRIER MODE
break;
case 'h': // help
Harmonic=atoi(optarg);
break;
case 'l': // loop mode
loop_mode_flag = true;
break;
case -1:
break;
case '?':
if (isprint(optopt) )
{
fprintf(stderr, "dvbrf: unknown option `-%c'.\n", optopt);
}
else
{
fprintf(stderr, "dvbrf: unknown option character `\\x%x'.\n", optopt);
}
print_usage();
exit(1);
break;
default:
print_usage();
exit(1);
break;
}/* end switch a */
}/* end while getopt() */
if(FileName==NULL) {fprintf(stderr,"Need an input\n");exit(1);}
if(FEC<0) {fprintf(stderr,"Need a FEC\n");exit(1);}
for (int i = 0; i < 0xb; i++) {
struct sigaction sa;
std::memset(&sa, 0, sizeof(sa));
sa.sa_handler = terminate;
sigaction(i, &sa, NULL);
}
FILE *tsfile=NULL;
if(strcmp(FileName,"-")==0)
tsfile=fopen("/dev/stdin","rb");
else
tsfile=fopen(FileName,"rb");
if (tsfile==NULL)
{
printf("input file issue\n");
exit(0);
}
int FifoSize=204*100*4;
int NumberofPhase=4;
phasedmasync dvbsmodul(SetFrequency/Harmonic,SampleRate,NumberofPhase,14,FifoSize);
padgpio pad;
pad.setlevel(7);
#define BURST_PACKET 10
#define BURST_SIZE 204*BURST_PACKET
int PhaseBuffer[BURST_SIZE*4*2]; //4 dibit by byte
static uint32_t BuffAligned[256*2];
static uchar *TsBuffer=(uchar *)BuffAligned ;
static unsigned char BuffIQ[204*2]; //QPSK 2bit per sample : 4 dibits by byte
static uchar *pRS204=NULL;
dvbsenco_init() ;
viterbi_init(FEC);
int MapDVBS[4]={0,3,1,2};//0,-pi/2,pi/2,pi
while(running)
{
int nbread=fread(TsBuffer,sizeof(uchar),BURST_PACKET*188,tsfile);
if(nbread>0)
{
if(TsBuffer[0]!=0x47) fprintf(stderr,"SYNC ERROR \n");
for(int p=0;p<BURST_PACKET;p++)
{
pRS204 = dvbsenco (TsBuffer+p*188) ;
int NbIQOutput=viterbi (pRS204,BuffIQ);
int dibit=0;
for(int k=0;k<NbIQOutput;k++)
{
for(int i=3;i>=0;i--)
{
PhaseBuffer[dibit++]=MapDVBS[(BuffIQ[k]>>(i*2))&0x3];
}
}
dvbsmodul.SetPhaseSamples(PhaseBuffer,NbIQOutput*4);
}
}
else
{
printf("End of file\n");
if(loop_mode_flag)
fseek ( tsfile , 0 , SEEK_SET );
else
running=false;
}
}
dvbsmodul.stop();
}

1162
src/dvb/dvbsenco8.s 100644

Plik diff jest za duży Load Diff

2867
src/dvb/fec100.c 100644

Plik diff jest za duży Load Diff

7
src/dvb/fec100.h 100644
Wyświetl plik

@ -0,0 +1,7 @@
typedef unsigned char uchar ; // 8 bit
typedef unsigned short uint16 ; // 16 bit
typedef unsigned int uint ; // 32 bits
void viterbi_init(int SetFEC);
uint16 viterbi (uchar *in, uchar *out);