1 #define GLOBAL_CLK 1
2
3 #include
4 #include
5 #include “def.h”
6 #include “option.h”
7 #include “2440addr.h”
8 #include “2440lib.h”
9 #include “2440slib.h”
10 #include “mmu.h”
11 #include “profile.h”
12 #include “memtest.h”
13
14 //extern置于變量或函數(shù)之前,以標示變量或函數(shù)的定義在別的文件中
15 extern char Image$$RO$$Limit[];
16 extern char Image$$RO$$Base[];
17 extern char Image$$RW$$Limit[];
18 extern char Image$$RW$$Base[];
19 extern char Image$$ZI$$Limit[];
20 extern char Image$$ZI$$Base[];
21 //RO是程序中的指令和常量;RO就是readonly,
22 //RW是程序中的已初始化變量; RW就是read/write,
23 // ZI是程序中的未初始化的變量;ZI就是zero;
24 //|Image$$RO$$Limit|:表示RO區(qū)末地址后面的地址,即RW數(shù)據(jù)源的起始地址
25 //|Image$$RW$$Base|:RW區(qū)在RAM里的執(zhí)行區(qū)起始地址,也就是編譯器選項RW_Base指定的地址
26 //|Image$$ZI$$Base|:ZI區(qū)在RAM里面的起始地址
27 //|Image$$ZI$$Limit|:ZI區(qū)在RAM里面的結束地址后面的一個地址
28
29 void Isr_Init(void);
30 void HaltUndef(void);
31 void HaltSwi(void);
32 void HaltPabort(void);
33 void HaltDabort(void);
34 void ClearMemory(void);
35
36 void Clk0_Enable(int clock_sel);
37 void Clk1_Enable(int clock_sel);
38 void Clk0_Disable(void);
39 void Clk1_Disable(void);
40
41 //extern置于變量或函數(shù)之前,以標示變量或函數(shù)的定義在別的文件中
42 extern void Lcd_TFT_Init(void);
43 extern void Lcd_TFT_Test( void ) ;
44 extern void Test_Touchpanel(void) ;
45 extern void Test_Adc(void) ;
46 extern void KeyScan_Test(void) ;
47 extern void RTC_Display(void) ;
48 extern void Test_IrDA_Tx(void) ;
49 extern void PlayMusicTest(void) ;
50 extern void RecordTest( void ) ;
51 extern void Test_Iic(void) ;
52 extern void Test_SDI(void) ;
53 extern void Camera_Test( void ) ;
54
55 //volatile影響編譯器編譯的結果,指出volatile變量是隨時可能發(fā)生變化的,與volatile變量有關的運算,不要進行編譯優(yōu)化。
56 volatile U32 downloadAddress;
57
58 //void (*restart)(void),定義一個指針,指針名為restart,指針指向函數(shù),函數(shù)的返回類型為void
59 // (void (*)(void))0×0,將0×0強制轉換,使其符合等號左邊的類型。
60 void (*restart)(void)=(void (*)(void))0×0;
61
62 volatile unsigned char *downPt;
63 volatile U32 downloadFileSize;
64 volatile U16 checkSum;
65 volatile unsigned int err=0;
66 volatile U32 totalDmaCount;
67
68 volatile int isUsbdSetConfiguration;
69
70 int download_run=0;
71 U32 tempDownloadAddress;
72 int menuUsed=0;
73
74 extern char Image$$RW$$Limit[];
75 U32 *pMagicNum=(U32 *)Image$$RW$$Limit;
76 int consoleNum;
77
78 /*在全局變量之前,加上關鍵字static,全局變量就被定義成為一個全局靜態(tài)變量。
79 1)內(nèi)存中的位置:靜態(tài)存儲區(qū)(靜態(tài)存儲區(qū)在整個程序運行期間都存在)
80 2)初始化:未經(jīng)初始化的全局靜態(tài)變量會被程序自動初始化為0
81 3)作用域:全局靜態(tài)變量在聲明他的文件之外是不可見的。準確地將從定義之處開始到文件結尾*/
82 static U32 cpu_freq;
83 static U32 UPLL;
84
85 /*在函數(shù)的返回類型前加上關鍵字static,函數(shù)就被定義成為靜態(tài)函數(shù)。
86 函數(shù)的定義和聲明默認情況下是extern的,但靜態(tài)函數(shù)只是在聲明它的文件當中可見,不能被其他文件使用。*/
87 static void cal_cpu_bus_clk(void)
88 {
89 U32 val;
90 U8 m, p, s;
91 val = rMPLLCON;
92 m = (val>>12)&0xff; // m=92=MDIV
93 p = (val>>4)&0x3f; // p=1=PDIV
94 s = val&3; // s=1=SDIV
95
96 //(m+8)*FIN*2 不要超出32位數(shù)!
97 /* 按照手冊上面的計算,F(xiàn)out=2*m*Fin/(p*2s),其中Fin=12MHz。但m、p、s與上面的不一樣。公式中m=MDIV+8,p=PDIV+2,s=SDIV
98 (1<
99 FIN、FCLK在option.h中定義,F(xiàn)IN=12000000,經(jīng)計算FCLK=400MHz*/
100 FCLK = ((m+8)*(FIN/100)*2)/((p+2)*(1<
101 val = rCLKDIVN;
102 m = (val>>1)&3;//m=2=HDIVN
103 p = val&1; // P=1=PDIVN
104 val = rCAMDIVN;
105 // 由于之前沒有設置過CAMDIVN寄存器,所以是默認值
106 s=0x0000_0000,其最后兩位00,代表沒移位之前的CAMDIVN[9][8]
107 s = val>>8;
108 switch (m) {
109 case 0:
110 HCLK = FCLK;
111 break;
112 case 1:
113 HCLK = FCLK>>1;
114 break;
115 case 2:
116 if(s&2)
117 m=2,CAMDIVN[9]=0,表示FCLK:HCK=1:4
118 HCLK = FCLK>>3;
119 else
120 HCLK = FCLK>>2;
121 break;
122 case 3:
123 if(s&1)
124 HCLK = FCLK/6;
125 else
126 HCLK = FCLK/3;
127 break;
128 }
129 if(p)
130 //p=1,表示HCLK:PCLK=1:2
131 PCLK = HCLK>>1;
132 else
133 PCLK = HCLK;
134 if(s&0×10)
135 cpu_freq = HCLK;
136 else
137 // s=0,表示CPU頻率等于FCLK頻率
138 cpu_freq = FCLK;
139 // UPLLCON在Main函數(shù)里沒有設置,但在2440init里有設置
140 val = rUPLLCON;
141 m=56=MDIV
142 m = (val>>12)&0xff;
143 p=2=PDIV
144 p = (val>>4)&0x3f;
145 s=2=SDIV
146 s = val&3;
147 //UPLL的計算方法,同MPLL一樣,經(jīng)計算知,UPLL=48MHz
148 UPLL = ((m+8)*FIN)/((p+2)*(1<
149 /*根據(jù)2440init里CLKVAL的值,CLKDIVN[3]=DIVN_UPLL=0
150 rCLKDIVN&8=0,所以UCLK=UPLL=48MHz*/
151 UCLK = (rCLKDIVN&8)?(UPLL>>1):UPLL;
152 }
153
154 void Temp_function() { Uart_Printf(“nPlease input 1-11 to select test!!!n”); }
155
156 /* 定義一個結構體,沒有結構體類型名稱,但其結構體變量為CmdTip[],為一個數(shù)組。
157 結構體成員:
158 有一個指針,名為fun。其指向一個函數(shù),函數(shù)的返回類型為void。
159 有一個指針,名為tip,其指向字符型。
160 函數(shù)的函數(shù)名就像數(shù)組名一樣,其本身就是指針,代表函數(shù)的入口地址*/
161 struct {
162 void (*fun)(void);
163 char *tip;
164 }CmdTip[] = {
165 { Temp_function, “Please input 1-11 to select test” } ,
166 { BUZZER_PWM_Test, “Test PWM” } ,
167 { RTC_Display, “RTC time display” } ,
168 { Test_Adc, “Test ADC” } ,
169 { KeyScan_Test, “Test interrupt and key scan” } ,
170 { Test_Touchpanel, “Test Touchpanel” } ,
171 { Lcd_TFT_Test, “Test TFT LCD” } ,
172 { Test_Iic, “Test IIC EEPROM” } ,
173 { PlayMusicTest, “UDA1341 play music” } ,
174 { RecordTest, “UDA1341 record voice” } ,
175 { Test_SDI, “Test SD Card” } ,
176 { Camera_Test, “Test CMOS Camera”},
177 { 0, 0}
178 };
1 void Main(void)
2 {
3 char *mode;
4 int i;
5 U8 key;
6 U32 mpll_val = 0 ;
7 //U32 divn_upll = 0 ;
8 /*#if如果給定條件為真,則編譯下面代碼,直到出現(xiàn)#else、#elif或#endif為止;否則就不編譯。
9 ADS10在option.h定義,ADS10=1,這段沒有