Move to PLLC because PLLA used by openvg

This commit is contained in:
F5OEO 2018-10-03 14:05:01 +00:00
parent 3da98b2e0f
commit 73f0ba145b
7 changed files with 130 additions and 49 deletions

View file

@ -48,7 +48,7 @@ void SimpleTest(uint64_t Freq)
clkgpio clk; clkgpio clk;
clk.print_clock_tree(); clk.print_clock_tree();
clk.SetPllNumber(clk_plla,0); clk.SetPllNumber(clk_pllc,0);
//clk.SetAdvancedPllMode(true); //clk.SetAdvancedPllMode(true);
//clk.SetPLLMasterLoop(0,4,0); //clk.SetPLLMasterLoop(0,4,0);
@ -189,41 +189,26 @@ void SimpleTestbpsk(uint64_t Freq)
clkgpio clk; clkgpio clk;
clk.print_clock_tree(); clk.print_clock_tree();
int SR=100000;
int FifoSize=1024;
int SR=250000;
int FifoSize=10000;
int NumberofPhase=2; int NumberofPhase=2;
phasedmasync biphase(Freq,SR,NumberofPhase,14,FifoSize); phasedmasync biphase(Freq,SR,NumberofPhase,14,FifoSize);
padgpio pad;
pad.setlevel(7);
int lastphase=0; int lastphase=0;
#define BURST_SIZE 100
int PhaseBuffer[BURST_SIZE];
while(running) while(running)
{ {
//usleep(FifoSize*1000000.0*1.0/(8.0*SR)); for(int i=0;i<BURST_SIZE;i++)
usleep(10);
int Available=biphase.GetBufferAvailable();
if(Available>256)
{ {
int Index=biphase.GetUserMemIndex(); int phase=(rand()%NumberofPhase);
PhaseBuffer[i]=phase;
for(int i=0;i<Available;i++)
{
int phase=(rand()%NumberofPhase);
biphase.SetPhase(Index+i,phase);
}
/*
for(int i=0;i<Available/2;i++)
{
int phase=2*(rand()%NumberofPhase/2);
biphase.SetPhase(Index+i*2,(phase+lastphase)/2);
biphase.SetPhase(Index+i*2+1,phase);
lastphase=phase;
}*/
/*for(int i=0;i<Available;i++)
{
lastphase=(lastphase+1)%NumberofPhase;
biphase.SetPhase(Index+i,lastphase);
}*/
} }
biphase.SetPhaseSamples(PhaseBuffer,BURST_SIZE);
} }
biphase.stop(); biphase.stop();
} }
@ -408,9 +393,9 @@ int main(int argc, char* argv[])
} }
//SimpleTest(Freq); //SimpleTest(Freq);
//SimpleTestbpsk(Freq); SimpleTestbpsk(Freq);
//SimpleTestFileIQ(Freq); //SimpleTestFileIQ(Freq);
SimpleTestDMA(Freq); //SimpleTestDMA(Freq);
//SimpleTestAm(Freq); //SimpleTestAm(Freq);
//SimpleTestOOK(Freq); //SimpleTestOOK(Freq);
//SimpleTestBurstFsk(Freq); //SimpleTestBurstFsk(Freq);

View file

@ -73,7 +73,7 @@ This program is free software: you can redistribute it and/or modify
cbp->info = BCM2708_DMA_NO_WIDE_BURSTS | BCM2708_DMA_WAIT_RESP ; cbp->info = BCM2708_DMA_NO_WIDE_BURSTS | BCM2708_DMA_WAIT_RESP ;
cbp->src = mem_virt_to_phys(&usermem[samplecnt*registerbysample]); cbp->src = mem_virt_to_phys(&usermem[samplecnt*registerbysample]);
cbp->dst = 0x7E000000 + (PLLA_FRAC<<2) + CLK_BASE ; cbp->dst = 0x7E000000 + (PLLC_FRAC<<2) + CLK_BASE ;
cbp->length = 4; cbp->length = 4;
cbp->stride = 0; cbp->stride = 0;
cbp->next = mem_virt_to_phys(cbp + 1); cbp->next = mem_virt_to_phys(cbp + 1);

View file

@ -87,6 +87,7 @@ int clkgpio::SetPllNumber(int PllNo, int MashType)
else else
Mash = 0; Mash = 0;
gpioreg[GPCLK_CNTL] = 0x5A000000 | (Mash << 9) | pllnumber /*|(1 << 5)*/; //5 is Reset CLK gpioreg[GPCLK_CNTL] = 0x5A000000 | (Mash << 9) | pllnumber /*|(1 << 5)*/; //5 is Reset CLK
usleep(100);
gpioreg[GPCLK_CNTL_2] = 0x5A000000 | (Mash << 9) | pllnumber /*|(1 << 5)*/; //5 is Reset CLK gpioreg[GPCLK_CNTL_2] = 0x5A000000 | (Mash << 9) | pllnumber /*|(1 << 5)*/; //5 is Reset CLK
usleep(100); usleep(100);
Pllfrequency = GetPllFrequency(pllnumber); Pllfrequency = GetPllFrequency(pllnumber);
@ -124,6 +125,7 @@ int clkgpio::SetClkDivFrac(uint32_t Div, uint32_t Frac)
{ {
gpioreg[GPCLK_DIV] = 0x5A000000 | ((Div) << 12) | Frac; gpioreg[GPCLK_DIV] = 0x5A000000 | ((Div) << 12) | Frac;
usleep(100);
gpioreg[GPCLK_DIV_2] = 0x5A000000 | ((Div) << 12) | Frac; gpioreg[GPCLK_DIV_2] = 0x5A000000 | ((Div) << 12) | Frac;
usleep(100); usleep(100);
fprintf(stderr, "Clk Number %d div %d frac %d\n", pllnumber, Div, Frac); fprintf(stderr, "Clk Number %d div %d frac %d\n", pllnumber, Div, Frac);
@ -136,9 +138,9 @@ int clkgpio::SetMasterMultFrac(uint32_t Mult, uint32_t Frac)
{ {
//fprintf(stderr,"Master Mult %d Frac %d\n",Mult,Frac); //fprintf(stderr,"Master Mult %d Frac %d\n",Mult,Frac);
gpioreg[PLLA_CTRL] = (0x5a << 24) | (0x21 << 12) | Mult; //PDIV=1 gpioreg[PLLC_CTRL] = (0x5a << 24) | (0x21 << 12) | Mult; //PDIV=1
usleep(100); usleep(100);
gpioreg[PLLA_FRAC] = 0x5A000000 | Frac; gpioreg[PLLC_FRAC] = 0x5A000000 | Frac;
return 0; return 0;
} }
@ -300,18 +302,20 @@ int clkgpio::SetCenterFrequency(uint64_t Frequency, int Bandwidth)
SetFrequency(0); SetFrequency(0);
usleep(1000); usleep(1000);
if ((gpioreg[CM_LOCK] & CM_LOCK_FLOCKA) > 0) if ((gpioreg[CM_LOCK] & CM_LOCK_FLOCKC) > 0)
fprintf(stderr, "Master PLLA Locked\n"); fprintf(stderr, "Master PLLC Locked\n");
else else
fprintf(stderr, "Warning ! Master PLLA NOT Locked !!!!\n"); fprintf(stderr, "Warning ! Master PLLC NOT Locked !!!!\n");
SetClkDivFrac(PllFixDivider, 0x0); // NO MASH !!!! SetClkDivFrac(PllFixDivider, 0x0); // NO MASH !!!!
usleep(100); usleep(100);
usleep(100); usleep(100);
gpioreg[GPCLK_CNTL] = 0x5A000000 | (Mash << 9) | pllnumber | (1 << 4); //4 is START CLK gpioreg[GPCLK_CNTL] = 0x5A000000 | (Mash << 9) | pllnumber | (1 << 4); //4 is START CLK
usleep(100);
gpioreg[GPCLK_CNTL_2] = 0x5A000000 | (Mash << 9) | pllnumber | (1 << 4); //4 is START CLK gpioreg[GPCLK_CNTL_2] = 0x5A000000 | (Mash << 9) | pllnumber | (1 << 4); //4 is START CLK
usleep(100); usleep(100);
gpioreg[GPCLK_CNTL] = 0x5A000000 | (Mash << 9) | pllnumber | (1 << 4); //4 is START CLK gpioreg[GPCLK_CNTL] = 0x5A000000 | (Mash << 9) | pllnumber | (1 << 4); //4 is START CLK
usleep(100);
gpioreg[GPCLK_CNTL_2] = 0x5A000000 | (Mash << 9) | pllnumber | (1 << 4); //4 is START CLK gpioreg[GPCLK_CNTL_2] = 0x5A000000 | (Mash << 9) | pllnumber | (1 << 4); //4 is START CLK
usleep(100); usleep(100);
} }
@ -338,26 +342,44 @@ void clkgpio::SetAdvancedPllMode(bool Advanced)
ModulateFromMasterPLL = Advanced; ModulateFromMasterPLL = Advanced;
if (ModulateFromMasterPLL) if (ModulateFromMasterPLL)
{ {
SetPllNumber(clk_plla, 0); // Use PPL_A , Do not USE MASH which generates spurious //We must change Clk dependant from PLLC as we will modulate it
gpioreg[CM_PLLA] = 0x5A00022A; // Enable Plla_PER // switch the core over to PLLA
gpioreg[CORECLK_DIV] = (0x5a<<24) | (4<<12) ; // core div 4
usleep(100);
gpioreg[CORECLK_CNTL] = (0x5a<<24) | (1<<4) | (4); // run, src=PLLA
// switch the EMMC over to PLLD
int clktmp;
clktmp = gpioreg[EMMCCLK_CNTL];
gpioreg[EMMCCLK_CNTL] = (0xF0F&clktmp) | (0x5a<<24) ; // clear run
usleep(100);
gpioreg[EMMCCLK_CNTL] = (0xF00&clktmp) | (0x5a<<24) | (6); // src=PLLD
usleep(100);
gpioreg[EMMCCLK_CNTL] = (0xF00&clktmp) | (0x5a<<24) | (1<<4) | (6); // run , src=PLLD
SetPllNumber(clk_pllc, 0); // Use PLL_C , Do not USE MASH which generates spurious
//gpioreg[CM_PLLA] = 0x5A00022A; // Enable PllA_PER
gpioreg[CM_PLLC] = 0x5A00022A; // Enable PllA_PER
usleep(100); usleep(100);
uint32_t ana[4]; uint32_t ana[4];
for (int i = 3; i >= 0; i--) for (int i = 3; i >= 0; i--)
{ {
ana[i] = gpioreg[(A2W_PLLA_ANA0 ) + i]; ana[i] = gpioreg[(A2W_PLLC_ANA0 ) + i];
} }
ana[1]&=~(1<<14); // No use prediv means Frequency ana[1]&=~(1<<14); // No use prediv means Frequency
//ana[1] |= (1 << 14); // use prediv means Frequency*2 //ana[1] |= (1 << 14); // use prediv means Frequency*2
for (int i = 3; i >= 0; i--) for (int i = 3; i >= 0; i--)
{ {
gpioreg[(A2W_PLLA_ANA0 ) + i] = (0x5A << 24) | ana[i]; gpioreg[(A2W_PLLC_ANA0 ) + i] = (0x5A << 24) | ana[i];
} }
usleep(100); usleep(100);
gpioreg[PLLA_CORE] = 0x5A000000|(1<<8);//Disable gpioreg[PLLC_CORE0] = 0x5A000000|(1<<8);//Disable
gpioreg[PLLA_PER] = 0x5A000001; // Divisor gpioreg[PLLC_PER] = 0x5A000001; // Divisor
usleep(100); usleep(100);
} }
} }
@ -367,14 +389,14 @@ void clkgpio::SetPLLMasterLoop(int Ki,int Kp,int Ka)
uint32_t ana[4]; uint32_t ana[4];
for (int i = 3; i >= 0; i--) for (int i = 3; i >= 0; i--)
{ {
ana[i] = gpioreg[(A2W_PLLA_ANA0 ) + i]; ana[i] = gpioreg[(A2W_PLLC_ANA0 ) + i];
} }
ana[1]=(Ki<<A2W_PLL_KI_SHIFT)|(Kp<<A2W_PLL_KP_SHIFT)|(Ka<<A2W_PLL_KA_SHIFT); ana[1]=(Ki<<A2W_PLL_KI_SHIFT)|(Kp<<A2W_PLL_KP_SHIFT)|(Ka<<A2W_PLL_KA_SHIFT);
fprintf(stderr,"Loop parameter =%x\n",ana[1]); fprintf(stderr,"Loop parameter =%x\n",ana[1]);
for (int i = 3; i >= 0; i--) for (int i = 3; i >= 0; i--)
{ {
gpioreg[(A2W_PLLA_ANA0 ) + i] = (0x5A << 24) | ana[i]; gpioreg[(A2W_PLLC_ANA0 ) + i] = (0x5A << 24) | ana[i];
} }
usleep(100) ; usleep(100) ;
//Only PLLA for now //Only PLLA for now

View file

@ -97,6 +97,79 @@ class generalgpio:public gpio
#define EMMCCLK_CNTL (0x1C0/4) #define EMMCCLK_CNTL (0x1C0/4)
#define EMMCCLK_DIV (0x1C4/4) #define EMMCCLK_DIV (0x1C4/4)
#define CM_VPUCTL 0x008
#define CM_VPUDIV 0x00c
#define CM_SYSCTL 0x010
#define CM_SYSDIV 0x014
#define CM_PERIACTL 0x018
#define CM_PERIADIV 0x01c
#define CM_PERIICTL 0x020
#define CM_PERIIDIV 0x024
#define CM_H264CTL 0x028
#define CM_H264DIV 0x02c
#define CM_ISPCTL 0x030
#define CM_ISPDIV 0x034
#define CM_V3DCTL 0x038
#define CM_V3DDIV 0x03c
#define CM_CAM0CTL 0x040
#define CM_CAM0DIV 0x044
#define CM_CAM1CTL 0x048
#define CM_CAM1DIV 0x04c
#define CM_CCP2CTL 0x050
#define CM_CCP2DIV 0x054
#define CM_DSI0ECTL 0x058
#define CM_DSI0EDIV 0x05c
#define CM_DSI0PCTL 0x060
#define CM_DSI0PDIV 0x064
#define CM_DPICTL 0x068
#define CM_DPIDIV 0x06c
#define CM_GP0CTL 0x070
#define CM_GP0DIV 0x074
#define CM_GP1CTL 0x078
#define CM_GP1DIV 0x07c
#define CM_GP2CTL 0x080
#define CM_GP2DIV 0x084
#define CM_HSMCTL 0x088
#define CM_HSMDIV 0x08c
#define CM_OTPCTL 0x090
#define CM_OTPDIV 0x094
#define CM_PCMCTL 0x098
#define CM_PCMDIV 0x09c
#define CM_PWMCTL 0x0a0
#define CM_PWMDIV 0x0a4
#define CM_SLIMCTL 0x0a8
#define CM_SLIMDIV 0x0ac
#define CM_SMICTL 0x0b0
#define CM_SMIDIV 0x0b4
/* no definition for 0x0b8 and 0x0bc */
#define CM_TCNTCTL 0x0c0
# define CM_TCNT_SRC1_SHIFT 12
#define CM_TCNTCNT 0x0c4
#define CM_TECCTL 0x0c8
#define CM_TECDIV 0x0cc
#define CM_TD0CTL 0x0d0
#define CM_TD0DIV 0x0d4
#define CM_TD1CTL 0x0d8
#define CM_TD1DIV 0x0dc
#define CM_TSENSCTL 0x0e0
#define CM_TSENSDIV 0x0e4
#define CM_TIMERCTL 0x0e8
#define CM_TIMERDIV 0x0ec
#define CM_UARTCTL 0x0f0
#define CM_UARTDIV 0x0f4
#define CM_VECCTL 0x0f8
#define CM_VECDIV 0x0fc
#define CM_PULSECTL 0x190
#define CM_PULSEDIV 0x194
#define CM_SDCCTL 0x1a8
#define CM_SDCDIV 0x1ac
#define CM_ARMCTL 0x1b0
#define CM_AVEOCTL 0x1b8
#define CM_AVEODIV 0x1bc
#define CM_EMMCCTL 0x1c0
#define CM_EMMCDIV 0x1c4
#define CM_LOCK (0x114/4) #define CM_LOCK (0x114/4)
# define CM_LOCK_FLOCKH (1<<12) # define CM_LOCK_FLOCKH (1<<12)
# define CM_LOCK_FLOCKD (1<<11) # define CM_LOCK_FLOCKD (1<<11)
@ -170,6 +243,7 @@ class generalgpio:public gpio
#define XOSC_CTRL (0x1190/4) #define XOSC_CTRL (0x1190/4)
#define XOSC_FREQUENCY 19200000 #define XOSC_FREQUENCY 19200000
//Parent PLL
enum {clk_gnd,clk_osc,clk_debug0,clk_debug1,clk_plla,clk_pllc,clk_plld,clk_hdmi}; enum {clk_gnd,clk_osc,clk_debug0,clk_debug1,clk_plla,clk_pllc,clk_plld,clk_hdmi};
class clkgpio:public gpio class clkgpio:public gpio

View file

@ -96,7 +96,7 @@ void iqdmasync::SetDmaAlgo()
cbp->info = BCM2708_DMA_NO_WIDE_BURSTS | BCM2708_DMA_WAIT_RESP ; cbp->info = BCM2708_DMA_NO_WIDE_BURSTS | BCM2708_DMA_WAIT_RESP ;
cbp->src = mem_virt_to_phys(&usermem[samplecnt*registerbysample]); cbp->src = mem_virt_to_phys(&usermem[samplecnt*registerbysample]);
cbp->dst = 0x7E000000 + (PLLA_FRAC<<2) + CLK_BASE ; cbp->dst = 0x7E000000 + (PLLC_FRAC<<2) + CLK_BASE ;
cbp->length = 4; cbp->length = 4;
cbp->stride = 0; cbp->stride = 0;
cbp->next = mem_virt_to_phys(cbp + 1); cbp->next = mem_virt_to_phys(cbp + 1);

View file

@ -77,7 +77,7 @@ void ngfmdmasync::SetDmaAlgo()
cbp->info = BCM2708_DMA_NO_WIDE_BURSTS | BCM2708_DMA_WAIT_RESP ; cbp->info = BCM2708_DMA_NO_WIDE_BURSTS | BCM2708_DMA_WAIT_RESP ;
cbp->src = mem_virt_to_phys(&usermem[samplecnt*registerbysample]); cbp->src = mem_virt_to_phys(&usermem[samplecnt*registerbysample]);
cbp->dst = 0x7E000000 + (PLLA_FRAC<<2) + CLK_BASE ; cbp->dst = 0x7E000000 + (PLLC_FRAC<<2) + CLK_BASE ;
cbp->length = 4; cbp->length = 4;
cbp->stride = 0; cbp->stride = 0;
cbp->next = mem_virt_to_phys(cbp + 1); cbp->next = mem_virt_to_phys(cbp + 1);

View file

@ -28,7 +28,7 @@ phasedmasync::phasedmasync(uint64_t TuneFrequency,uint32_t SampleRateIn,int Numb
{ {
SampleRate=SampleRateIn; SampleRate=SampleRateIn;
SetMode(pwm1pinrepeat); SetMode(pwm1pinrepeat);
pwmgpio::SetPllNumber(clk_plla,0); pwmgpio::SetPllNumber(clk_pllc,0);
tunefreq=TuneFrequency*NumberOfPhase; tunefreq=TuneFrequency*NumberOfPhase;
#define MAX_PWM_RATE 360000000 #define MAX_PWM_RATE 360000000