Skip to content

Commit

Permalink
Merge pull request #355 from jonk6/master
Browse files Browse the repository at this point in the history
Fix for Issue #311
  • Loading branch information
robotastic authored May 16, 2020
2 parents a9f0ed2 + b460d2f commit 7020b20
Show file tree
Hide file tree
Showing 3 changed files with 52 additions and 52 deletions.
10 changes: 5 additions & 5 deletions lib/lfsr/bit_utils.h
Original file line number Diff line number Diff line change
Expand Up @@ -53,7 +53,7 @@ Eigen::VectorXi* dibits_to_bits(Eigen::VectorXi &dibits) {
}

// Tested OK
Eigen::VectorXi *mk_array(unsigned long n, unsigned l) {
Eigen::VectorXi *mk_array(unsigned long long n, unsigned l) {

Eigen::VectorXi *a = new Eigen::VectorXi(l);
for(int i=l-1; i>=0; i--) {
Expand All @@ -63,11 +63,11 @@ Eigen::VectorXi *mk_array(unsigned long n, unsigned l) {
return a;
}

long unsigned mk_int(Eigen::VectorXi a) {
long unsigned res = 0L;
unsigned long long mk_int(Eigen::VectorXi a) {
unsigned long long res = 0ULL;
for (unsigned i=0; i< a.size(); i++) {
res *= 2;
res += (a(i) & 1);
res *= 2ULL;
res += (unsigned long long)(a(i) & 1);
}
return res;
}
Expand Down
88 changes: 44 additions & 44 deletions lib/lfsr/lfsr.cxx
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
/*
* lfsr.h
* lfsr.cxx
*
* Translation of lfsr.py to c++ - source file
*
Expand Down Expand Up @@ -54,12 +54,12 @@ const char * p25p2_lfsr::getXorChars(unsigned &len) const {

Eigen::VectorXi * p25p2_lfsr::mk_xor_bits(unsigned long nac, unsigned long sysid, unsigned long wacn) {

unsigned long n = 16777216*wacn + 4096*sysid + nac;
unsigned long long int n = 16777216ULL*wacn + 4096*sysid + nac;
Eigen::VectorXi *reg = mk_array(n, 44);

Eigen::VectorXi product = reg->transpose()*M;

long unsigned sreg = mk_int(product);
unsigned long long sreg = mk_int(product);

const unsigned ssize = 4320;
Eigen::VectorXi *s = new Eigen::VectorXi(ssize);
Expand All @@ -74,55 +74,55 @@ Eigen::VectorXi * p25p2_lfsr::mk_xor_bits(unsigned long nac, unsigned long sysid
}


long unsigned p25p2_lfsr::asm_reg( long unsigned s[6] ) {
s[0] = s[0] & 0xfL;
s[1] = s[1] & 0x1fL;
s[2] = s[2] & 0x3fL;
s[3] = s[3] & 0x1fL;
s[4] = s[4] & 0x3fffL;
s[5] = s[5] & 0x3ffL;
unsigned long long p25p2_lfsr::asm_reg(unsigned long long s[6] ) {
s[0] = s[0] & 0xfULL;
s[1] = s[1] & 0x1fULL;
s[2] = s[2] & 0x3fULL;
s[3] = s[3] & 0x1fULL;
s[4] = s[4] & 0x3fffULL;
s[5] = s[5] & 0x3ffULL;
return (s[0]<<40)+(s[1]<<35)+(s[2]<<29)+(s[3]<<24)+(s[4]<<10)+s[5];
}

long unsigned * p25p2_lfsr::disasm_reg(long unsigned r) {
unsigned long long * p25p2_lfsr::disasm_reg(unsigned long long r) {

long unsigned *s = new long unsigned[6];
s[0] = (r>>40) & 0xfL;
s[1] = (r>>35) & 0x1fL;
s[2] = (r>>29) & 0x3fL;
s[3] = (r>>24) & 0x1fL;
s[4] = (r>>10) & 0x3fffL;
s[5] = r & 0x3ffL;
unsigned long long *s = new unsigned long long[6];
s[0] = (r>>40) & 0xfULL;
s[1] = (r>>35) & 0x1fULL;
s[2] = (r>>29) & 0x3fULL;
s[3] = (r>>24) & 0x1fULL;
s[4] = (r>>10) & 0x3fffULL;
s[5] = r & 0x3ffULL;

return s;
}

long unsigned p25p2_lfsr::cyc_reg(long unsigned reg) {

long unsigned *s = disasm_reg(reg);
long unsigned cy1 = (s[0] >> 3) & 1L;
long unsigned cy2 = (s[1] >> 4) & 1L;
long unsigned cy3 = (s[2] >> 5) & 1L;
long unsigned cy4 = (s[3] >> 4) & 1L;
long unsigned cy5 = (s[4] >> 13) & 1L;
long unsigned cy6 = (s[5] >> 9) & 1L;
long unsigned x1 = cy1 ^ cy2;
long unsigned x2 = cy1 ^ cy3;
long unsigned x3 = cy1 ^ cy4;
long unsigned x4 = cy1 ^ cy5;
long unsigned x5 = cy1 ^ cy6;
s[0] = (s[0] << 1) & 0xfL;
s[1] = (s[1] << 1) & 0x1fL;
s[2] = (s[2] << 1) & 0x3fL;
s[3] = (s[3] << 1) & 0x1fL;
s[4] = (s[4] << 1) & 0x3fffL;
s[5] = (s[5] << 1) & 0x3ffL;
s[0] = s[0] | (x1 & 1L);
s[1] = s[1] | (x2 & 1L);
s[2] = s[2] | (x3 & 1L);
s[3] = s[3] | (x4 & 1L);
s[4] = s[4] | (x5 & 1L);
s[5] = s[5] | (cy1 & 1L);
unsigned long long p25p2_lfsr::cyc_reg(unsigned long long reg) {

unsigned long long *s = disasm_reg(reg);
unsigned long long cy1 = (s[0] >> 3) & 1L;
unsigned long long cy2 = (s[1] >> 4) & 1L;
unsigned long long cy3 = (s[2] >> 5) & 1L;
unsigned long long cy4 = (s[3] >> 4) & 1L;
unsigned long long cy5 = (s[4] >> 13) & 1L;
unsigned long long cy6 = (s[5] >> 9) & 1L;
unsigned long long x1 = cy1 ^ cy2;
unsigned long long x2 = cy1 ^ cy3;
unsigned long long x3 = cy1 ^ cy4;
unsigned long long x4 = cy1 ^ cy5;
unsigned long long x5 = cy1 ^ cy6;
s[0] = (s[0] << 1) & 0xfULL;
s[1] = (s[1] << 1) & 0x1fULL;
s[2] = (s[2] << 1) & 0x3fULL;
s[3] = (s[3] << 1) & 0x1fULL;
s[4] = (s[4] << 1) & 0x3fffULL;
s[5] = (s[5] << 1) & 0x3ffULL;
s[0] = s[0] | (x1 & 1ULL);
s[1] = s[1] | (x2 & 1ULL);
s[2] = s[2] | (x3 & 1ULL);
s[3] = s[3] | (x4 & 1ULL);
s[4] = s[4] | (x5 & 1ULL);
s[5] = s[5] | (cy1 & 1ULL);

return asm_reg(s);
}
6 changes: 3 additions & 3 deletions lib/lfsr/lfsr.h
Original file line number Diff line number Diff line change
Expand Up @@ -24,9 +24,9 @@ class p25p2_lfsr {

Eigen::VectorXi * mk_xor_bits(unsigned long, unsigned long, unsigned long);

static long unsigned asm_reg( long unsigned s[6] );
static long unsigned * disasm_reg(long unsigned r);
static long unsigned cyc_reg(long unsigned reg);
static unsigned long long asm_reg(unsigned long long s[6] );
static unsigned long long * disasm_reg(unsigned long long r);
static unsigned long long cyc_reg(unsigned long long reg);

Eigen::VectorXi *xorsyms;
std::string *xor_chars;
Expand Down

0 comments on commit 7020b20

Please sign in to comment.