S3C2440 裸机程序之音频

发布时间:2024-07-22  

/****************************************************************
 NAME: u2440mon.c
 DESC: u2440mon entry point,menu,download
 HISTORY:
 Mar.25.2002:purnnamu: S3C2400X profile.c is ported for S3C2410X.
 Mar.27.2002:purnnamu: DMA is enabled.
 Apr.01.2002:purnnamu: isDownloadReady flag is added.
 Apr.10.2002:purnnamu: - Selecting menu is available in the waiting loop. 
                         So, isDownloadReady flag gets not needed
                       - UART ch.1 can be selected for the console.
 Aug.20.2002:purnnamu: revision number change 0.2 -> R1.1       
 Sep.03.2002:purnnamu: To remove the power noise in the USB signal, the unused CLKOUT0,1 is disabled.
 ****************************************************************/
#define GLOBAL_CLK  1

#include   //声明一些执行数值转换,内存分配以及其他类似工作的函数
#include   //字符串函数
#include "def.h"
#include "option.h"
#include "2440addr.h"
#include "2440lib.h"
#include "2440slib.h"
#include "mmu.h"
#include "profile.h"
#include "memtest.h"


extern char Image$$RO$$Limit[];
extern char Image$$RO$$Base[];
extern char Image$$RW$$Limit[];
extern char Image$$RW$$Base[];
extern char Image$$ZI$$Limit[];
extern char Image$$ZI$$Base[];

void Isr_Init(void);
void HaltUndef(void);
void HaltSwi(void);
void HaltPabort(void);
void HaltDabort(void);
void ClearMemory(void);


void Clk0_Enable(int clock_sel); 
void Clk1_Enable(int clock_sel);
void Clk0_Disable(void);
void Clk1_Disable(void);

//extern void TFT_LCD_Init(void);
//extern void TFT_LCD_Test(void);
extern void TFT_LCD_Init(void);
extern void TFT_LCD_Test(void);
extern void Test_Touchpanel(void) ;
extern void Test_Adc(void) ;  //adc test
extern void KeyScan_Test(void) ;
extern void RTC_Display(void) ;
extern void Test_IrDA_Tx(void) ;
extern void PlayMusicTest(void) ;
extern void RecordTest( void ) ;
extern void Test_Iic(void) ;
extern void Test_SDI(void) ;
extern void Camera_Test( void ) ;
//volatile影响编译器编译的结果,指出volatile变量是随时可能发生变化的,与volatile变量有关的运算,不要进行编译优化。
volatile U32 downloadAddress;
// void (*restart)(void),定义一个指针,指针名为restart,指针指向函数,函数的返回类型为void
//(void (*)(void))0x0,将0x0强制转换,使其符合等号左边的类型。
void (*restart)(void)=(void (*)(void))0x0;

volatile U8  *downPt;
volatile U32 downloadFileSize;
volatile U16 checkSum;
volatile U32 err=0;
volatile U32 totalDmaCount;

volatile S32 isUsbdSetConfiguration;

int download_run=0;
U32 tempDownloadAddress;
int menuUsed=0;

U32 *pMagicNum=(U32 *)Image$$RW$$Limit;
int consoleNum;
/*   在全局变量之前,加上关键字static,全局变量就被定义成为一个全局静态变量。
1)内存中的位置:静态存储区(静态存储区在整个程序运行期间都存在)
2)初始化:未经初始化的全局静态变量会被程序自动初始化为0
3)作用域:全局静态变量在声明他的文件之外是不可见的。准确地将从定义之处开始到文件结尾
*/
static U32 cpu_freq;
static U32 UPLL;
/*在函数的返回类型前加上关键字static,函数就被定义成为静态函数。
  函数的定义和声明默认情况下是extern的,但静态函数只是在声明它的文件当中可见,不能被其他文件使用。
*/
static void cal_cpu_bus_clk(void)
{
 U32 val;
 U8 m, p, s;
 
 val = rMPLLCON;
 m = (val>>12)&0xff;//m=92=MDIV
 p = (val>>4)&0x3f; //p=1=PDIV
 s = val&3;         //s=1=SDIV
/*按照手册上面的计算,Fout=2*m*Fin/(p*2s),其中Fin=12MHz。但m、p、s与上面的不一样。公式中m=MDIV+8,p=PDIV+2,s=SDIV
    (1<     FIN、FCLK在option.h中定义,FIN=12000000,经计算FCLK=400MHz
 */
 //(m+8)*FIN*2 不要超出32位数!
 FCLK = ((m+8)*(FIN/100)*2)/((p+2)*(1< 
 val = rCLKDIVN;
 m = (val>>1)&3; // m=2=HDIVN,HCLK=FCLK/4
 p = val&1;     //p=1=PDIVN
 val = rCAMDIVN; //由于之前没有设置过CAMDIVN寄存器,所以是默认值s=0x0,其最后两位00,代表没移位之前的CAMDIVN[9:8]
 s = val>>8;
 
 switch (m) {
 case 0:
  HCLK = FCLK;   //当HDIV[2:1]=00,HCLK=FCLK/1
  break;
 case 1:
  HCLK = FCLK>>1; //当HDIV[2:1]=01,HCLK=FCLK/2
  break;
 case 2:
  if(s&2)
   HCLK = FCLK>>3; //当HDIV[2:1]=10,CAMDIVN[9]=1,则表示HCLK=FCLK/8
  else
   HCLK = FCLK>>2; //当HDIV[2:1]=10,CAMDIVN[9]=0,则表示HCLK=FCLK/4
  break;
 case 3:
  if(s&1)
   HCLK = FCLK/6; //当HDIV[2:1]=11,CAMDIVN[8]=1,则表示HCLK=FCLK/6
  else
   HCLK = FCLK/3; //当HDIV[2:1]=11,CAMDIVN[8]=0,则表示HCLK=FCLK/3
  break;
 }
 
 if(p)
  PCLK = HCLK>>1; //当PDIVN=1,PCLK=HCLK/2
 else
  PCLK = HCLK;  //当PDIVN=0,PCLK=HCLK/1
 
 if(s&0x10)     //CAMDIVN[12]=0,CPU频率等于HCLK频率
  cpu_freq = HCLK;
 else
  cpu_freq = FCLK; //CAMDIVN[12]=1,表示CPU频率等于FCLK频率
  
 val = rUPLLCON;  //UPLLCON在Main函数里没有设置,但在2440init里有设置
 m = (val>>12)&0xff; //m=56=MDIV
 p = (val>>4)&0x3f;  //p=2=PDIV
 s = val&3;//s=2=SDIV
 UPLL = ((m+8)*FIN)/((p+2)*(1< UCLK = (rCLKDIVN&8)?(UPLL>>1):UPLL; //根据2440init里CLKVAL的值,CLKDIVN[3]=DIVN_UPLL=0,rCLKDIVN&8=0,所以UCLK=UPLL=48MHz
}

void Temp_function() { Uart_Printf("nPlease input 1-16 to select test!!!n"); }

struct {
 void (*fun)(void);   //声明一个结构体
 char  *tip;         //声明一个函数指针
}CmdTip[] = {           //结构体初始化
    { Temp_function, "Please input 1-16 to select test" } ,
    { BUZZER_PWM_Test, "Test PWM" } ,
    { RTC_Display, "RTC time display" } ,
    { Test_Adc, "Test ADC" } ,
    { KeyScan_Test, "Test interrupt and key scan" } ,
    { Test_Touchpanel, "Test Touchpanel" } ,
    { TFT_LCD_Test, "Test TFT-LCD or VGA1024x768 module" } ,
    { Test_Iic, "Test IIC EEPROM, if use QQ2440, please remove the LCD" } ,
    { PlayMusicTest, "UDA1341 play music" } ,
    { Test_SDI, "Test SD Card" } ,
    { Camera_Test, "Test CMOS Camera"},
    { 0, 0}      
   };


void Main(void)
{
 char *mode;
 int i;
 U8 key;
 U32 mpll_val = 0 ;
 //U32 divn_upll = 0 ;
//#if如果给定条件为真,则编译下面代码,直到出现#else、#elif或#endif为止;否则就不编译。ADS10在option.h定义,ADS10=1,这段没有任何作用    
 #if ADS10   
// __rt_lib_init(); //for ADS 1.0
 #endif
//端口初始化,设置GPA/B/C/D/E/F/G/H/J相应的管脚,EXTINT0/1/2/3  
 Port_Init();
//设置中断服务程序,初始化。把所有中断设置为IRQ模式,屏蔽所有中断请求 
 Isr_Init();
 
 i = 2 ; //don't use 100M!
  //boot_params.cpu_clk.val = 3;
 switch ( i ) {
 case 0: //200
  key = 12;
  mpll_val = (92<<12)|(4<<4)|(1);
  break;
 case 1: //300
  key = 13;
  mpll_val = (67<<12)|(1<<4)|(1);
  break;
 case 2: //400
 //设置时钟分频比的值,FCLK:HCLK:PCLK
  key = 14;
 //设置FCLK的值,MDIV=92,PDIV=1,SDIV=1
  mpll_val = (92<<12)|(1<<4)|(1);
  break;
 case 3: //440!!!
  key = 14;
  mpll_val = (102<<12)|(1<<4)|(1);
  break;
 default:
  key = 14;
  mpll_val = (92<<12)|(1<<4)|(1);
  break;
 }
 
 //init FCLK=400M, so change MPLL first
 ChangeMPllValue((mpll_val>>12)&0xff, (mpll_val>>4)&0x3f, mpll_val&3);
 ChangeClockDivider(key, 12);
 cal_cpu_bus_clk();
//串口设置:串口选择,串口波特率设置; 
 consoleNum = 0; // Uart 1 select for debug.
 Uart_Init( 0,115200 );
 Uart_Select( consoleNum );
 
 Beep(2000, 100);
 
 Uart_SendByte('n');
 Uart_Printf("<***********************************************>n");
 Uart_Printf("           SBC2440 Test Program VER1.0n");
 Uart_Printf("                www.arm9.netn");
 Uart_Printf("      Build time is: %s  %sn", __DATE__ , __TIME__  );
    Uart_Printf( "          Image$$RO$$Base  = 0x%xn", Image$$RO$$Base );
 Uart_Printf( "          Image$$RO$$Limit = 0x%xn", Image$$RO$$Limit );
 Uart_Printf( "          Image$$RW$$Base  = 0x%xn", Image$$RW$$Base );
 Uart_Printf( "          Image$$RW$$Limit = 0x%xn", Image$$RW$$Limit );
    Uart_Printf( "          Image$$ZI$$Base  = 0x%xn", Image$$ZI$$Base );
    Uart_Printf( "          Image$$ZI$$Limit = 0x%xn", Image$$ZI$$Limit );
 Uart_Printf("<***********************************************>n");
//不同种类的控制寄存器设置,这里主要是选择USB端口
 rMISCCR=rMISCCR&~(1<<3);  // 选择USB device,而不是USB host
 rMISCCR=rMISCCR&~(1<<13); // 设置Port1有效


//
//  USBD should be initialized first of all.
//
// isUsbdSetConfiguration=0;
 
// rd_dm9000_id();   //
// rGPBCON &= ~(3<<20); //CF_CARD Power
// rGPBCON |= 1<<20;
// rGPBDAT |= 1<<10;
// rDSC0 = 0x155;
// rDSC1 = 0x15555555;
//设置输出管脚驱动电流
 rDSC0 = 0x2aa;
 rDSC1 = 0x2aaaaaaa;
 //Enable NAND, USBD, PWM TImer, UART0,1 and GPIO clock,
 //the others must be enabled in OS!!!
//设置时钟控制寄存器,选择各个外部接口的时钟源
 rCLKCON = 0xfffff0;
 

文章来源于:电子工程世界    原文链接
本站所有转载文章系出于传递更多信息之目的,且明确注明来源,不希望被转载的媒体或个人可与我们联系,我们将立即进行删除处理。

我们与500+贴片厂合作,完美满足客户的定制需求。为品牌提供定制化的推广方案、专属产品特色页,多渠道推广,SEM/SEO精准营销以及与公众号的联合推广...详细>>

利用葫芦芯平台的卓越技术服务和新产品推广能力,原厂代理能轻松打入消费物联网(IOT)、信息与通信(ICT)、汽车及新能源汽车、工业自动化及工业物联网、装备及功率电子...详细>>

充分利用其强大的电子元器件采购流量,创新性地为这些物料提供了一个全新的窗口。我们的高效数字营销技术,不仅可以助你轻松识别与连接到需求方,更能够极大地提高“闲置物料”的处理能力,通过葫芦芯平台...详细>>

我们的目标很明确:构建一个全方位的半导体产业生态系统。成为一家全球领先的半导体互联网生态公司。目前,我们已成功打造了智能汽车、智能家居、大健康医疗、机器人和材料等五大生态领域。更为重要的是...详细>>

我们深知加工与定制类服务商的价值和重要性,因此,我们倾力为您提供最顶尖的营销资源。在我们的平台上,您可以直接接触到100万的研发工程师和采购工程师,以及10万的活跃客户群体...详细>>

凭借我们强大的专业流量和尖端的互联网数字营销技术,我们承诺为原厂提供免费的产品资料推广服务。无论是最新的资讯、技术动态还是创新产品,都可以通过我们的平台迅速传达给目标客户...详细>>

我们不止于将线索转化为潜在客户。葫芦芯平台致力于形成业务闭环,从引流、宣传到最终销售,全程跟进,确保每一个potential lead都得到妥善处理,从而大幅提高转化率。不仅如此...详细>>