add perl scripts to compute MTK RF Transceiver PLL settings
This commit is contained in:
parent
155cbeab1d
commit
b6156d3e3d
|
@ -0,0 +1,79 @@
|
|||
#!/usr/bin/perl
|
||||
|
||||
# Rx Mode and Tx Mode:
|
||||
# N = Nint + (Nfrac / 130) = (0.5*Fvco) / 26M
|
||||
# where 0 <= Nfrac < 130
|
||||
# where 0 <= Ninit <= 127 (as Nint is 7 bit)
|
||||
# where Fvco = 4 * Fch (GSM 850/900), Fvco = 2 * Fch (GSM 1800/1900)
|
||||
|
||||
# (Nint + (Nfrac / 130)) * 52 MHz = Fvco
|
||||
|
||||
sub mtk_fvco($$) {
|
||||
my ($nint, $nfrac) = @_;
|
||||
return ($nint + ($nfrac / 130)) * (26 * 2)
|
||||
}
|
||||
|
||||
sub hr() {
|
||||
printf("======================================================================\n");
|
||||
}
|
||||
|
||||
sub vco_print($$$)
|
||||
{
|
||||
my ($nint, $nfrac, $hiband) = @_;
|
||||
my $fvco = mtk_fvco($nint, $nfrac);
|
||||
my $mult;
|
||||
|
||||
if ($hiband == 1) {
|
||||
$mult = 2;
|
||||
} else {
|
||||
$mult = 4;
|
||||
}
|
||||
|
||||
printf("Fch=%4.2f (Fvco=%4.2f, Nint=%03u, Nfrac=%03u)\n",
|
||||
$fvco/$mult, $fvco, $nint, $nfrac);
|
||||
}
|
||||
|
||||
#for (my $nint = 0; $nint <= 127; $nint++) {
|
||||
# for (my $nfrac = 0; $nfrac <= 130; $nfrac++) {
|
||||
# vco_print($nint, $nfrac);
|
||||
# }
|
||||
#}
|
||||
|
||||
printf("PLL Rx Low Band:\n");
|
||||
for (my $nint = 68; $nint <= 73; $nint++) {
|
||||
#for GSM 810
|
||||
#for (my $b = 132; $b <= 150; $b++) {
|
||||
for (my $nfrac = 0; $nfrac <= 130; $nfrac++) {
|
||||
vco_print($nint, $nfrac, 0);
|
||||
}
|
||||
}
|
||||
|
||||
hr();
|
||||
printf("PLL Rx High Band:\n");
|
||||
for (my $nint = 69; $nint <= 79; $nint++) {
|
||||
for (my $nfrac = 0; $nfrac <= 130; $nfrac++) {
|
||||
vco_print($nint, $nfrac, 1);
|
||||
}
|
||||
}
|
||||
|
||||
hr();
|
||||
printf("PLL Tx Low Band:\n");
|
||||
for (my $nint = 63; $nint <= 70; $nint++) {
|
||||
for (my $nfrac = 0; $nfrac <= 130; $nfrac++) {
|
||||
vco_print($nint, $nfrac, 0);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
hr();
|
||||
printf("PLL Tx High Band\n");
|
||||
for (my $nint = 65; $nint <= 73; $nint++) {
|
||||
for (my $nfrac = 0; $nfrac <= 130; $nfrac++) {
|
||||
vco_print($nint, $nfrac, 1);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
|
||||
exit(0);
|
||||
|
File diff suppressed because it is too large
Load Diff
Loading…
Reference in New Issue