FreeCalypso > hg > fc-magnetite
diff src/cs/layer1/tpu_drivers/source0/tpudrv10.c @ 414:cbc25978be5a
tpudrv10.c: beginning to reconstruct the frequency programming function
author | Mychaela Falconia <falcon@freecalypso.org> |
---|---|
date | Fri, 19 Jan 2018 23:18:23 +0000 |
parents | 780fa76e9c9b |
children | b3d65ae5f02c |
line wrap: on
line diff
--- a/src/cs/layer1/tpu_drivers/source0/tpudrv10.c Fri Jan 19 21:07:28 2018 +0000 +++ b/src/cs/layer1/tpu_drivers/source0/tpudrv10.c Fri Jan 19 23:18:23 2018 +0000 @@ -143,19 +143,17 @@ /* EFFECTIVE DOWNLOADING THROUGH TSP */ /**************************************************************************/ /**************************************************************************/ -// rx & tx -typedef struct tx_rx_s -{ - UWORD16 farfcn0; - WORD8 ou; -} -T_TX_RX; struct synth_s { - // common - UWORD16 arfcn0; - UWORD16 limit; - T_TX_RX tx_rx[2]; + // common + UWORD16 arfcn0; + UWORD16 limit; + // Tx + UWORD16 ul_farfcn0; + WORD8 ul_sign; + // Rx + UWORD16 dl_farfcn0; + UWORD8 dl_mult; }; struct magic1_s { @@ -176,8 +174,8 @@ static const struct synth_s synth_900[] = { - { 0, 124, {{ 890, 1}, { 935, 4}}},// gsm 0 - 124 - {974, 1023, {{ 880, 1}, { 925, 4}}},// egsm 975 - 1023 + { 0, 124, 890, 1, 935, 4},// gsm 0 - 124 + {974, 1023, 880, 1, 925, 4},// egsm 975 - 1023 }; static const struct magic1_s magic1_900[] = @@ -201,7 +199,7 @@ static const struct synth_s synth_1800[] = { - {511, 885, {{1710, -1}, {1805, 1}}}, // dcs 512 - 885 + {511, 885, 1710, -1, 1805, 1}, // dcs 512 - 885 }; static const struct magic1_s magic1_1800[] = @@ -220,7 +218,7 @@ static const struct synth_s synth_1900[] = { - {511, 810, {{1850, -1}, {1930, 1}}}, // pcs 512 - 810; + {511, 810, 1850, -1, 1930, 1}, // pcs 512 - 810; }; static const struct magic1_s magic1_1900[] = @@ -235,7 +233,7 @@ static const struct synth_s synth_850[] = { - {127, 251, {{ 824, 1}, { 869, 4}}}, // gsm850 high + {127, 251, 824, 1, 869, 4}, // gsm850 }; static const struct magic1_s magic1_850[] = @@ -274,14 +272,36 @@ #if 0 UWORD32 calc_a_b(UWORD16 arfcn, UWORD8 downlink) { - UWORD32 farfcn; /* in 200 kHz units */ - UWORD32 n; /* B * P + A */ + UWORD32 farfcn; /* sp+0x1C, in 200 kHz units */ struct synth_s *s; + struct magic1_s *m1; + UWORD32 magic1; /* sp+0x24 */ + UWORD16 sp4; + UWORD32 sp0x14, sp0x18, sp0x20; s = rf_path[rf_index].synth; while(s->limit < arfcn) s++; + m1 = rf_path[rf_index].magic1; + while(m1->limit < arfcn) + m1++; + magic1 = m1->magic; + + if (downlink) { + sp0x20 = 0x27627 * s->dl_mult + 8; + farfcn = 5*s->dl_farfcn0 + (arfcn - s->arfcn0); + sp4 = farfcn * s->dl_mult; + sp0x18 = sp4 << 21; + sp0x14 = sp0x20 * farfcn; + } else { + sp0x20 = 0x2762F; + farfcn = 5*s->ul_farfcn0 + (arfcn - s->arfcn0); + sp4 = magic1 * s->ul_sign + farfcn; + sp0x18 = sp4 << 21; + sp0x14 = sp0x20 * (magic1 * s->ul_sign + farfcn); + } + rf_chip_band = s->rf_chip_band; // Convert the ARFCN to the channel frequency (times 5 to avoid the decimal value)