2440lib.c
上传用户:qiulin1960
上传日期:2013-10-16
资源大小:2844k
文件大小:10k
源码类别:

Windows CE

开发平台:

Windows_Unix

  1. //
  2. // Copyright (c) Microsoft Corporation.  All rights reserved.
  3. //
  4. //
  5. // Use of this source code is subject to the terms of the Microsoft end-user
  6. // license agreement (EULA) under which you licensed this SOFTWARE PRODUCT.
  7. // If you did not accept the terms of the EULA, you are not authorized to use
  8. // this source code. For a copy of the EULA, please see the LICENSE.RTF on your
  9. // install media.
  10. //
  11. /*++
  12. THIS CODE AND INFORMATION IS PROVIDED "AS IS" WITHOUT WARRANTY OF
  13. ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING BUT NOT LIMITED TO
  14. THE IMPLIED WARRANTIES OF MERCHANTABILITY AND/OR FITNESS FOR A
  15. PARTICULAR PURPOSE.
  16. --*/
  17. //===================================================================
  18. // File Name : 2440lib.c
  19. // Function  : S3C2440 PLL,Uart, LED, Port Init
  20. // Program   : Shin, On Pil (SOP)
  21. // Date      : March 20, 2002
  22. // Version   : 1.0
  23. // History
  24. //   0.0 : Programming start (February 20,2002) -> SOP
  25. //  1.0 : Modified for SMDK2440 PPC2003 BSP ( November 29, 2003 ) -> HMSEO
  26. //  History : 2006.03.27 ver 2.0 *
  27. //          : Modified for QT2440 by wujiarui
  28. //===================================================================
  29. #include "def.h"
  30. #include "option.h"
  31. #include "2440addr.h"
  32. #include "2440lib.h"
  33. #include "2440slib.h" 
  34. #include <stdarg.h>
  35. #include <string.h>
  36. #include <stdlib.h>
  37. #include <stdio.h>
  38. #include <ctype.h>
  39. void MMU_SetAsyncBusMode(void);
  40. #define BAUD_RATE       115200
  41. #define WRITE_UART      WrUTXH1
  42. #define UART_STATUS     rUTRSTAT1
  43. //***************************[ PORTS ]****************************************************
  44. void Port_Init(void)
  45. {
  46.     //CAUTION:Follow the configuration order for setting the ports. 
  47.     // 1) setting value(GPnDAT) 
  48.     // 2) setting control register  (GPnCON)
  49.     // 3) configure pull-up resistor(GPnUP)  
  50.     //32bit data bus configuration  
  51.     //*** PORT A GROUP
  52.     //Ports  : GPA22 GPA21  GPA20 GPA19 GPA18 GPA17 GPA16 GPA15 GPA14 GPA13 GPA12  
  53.     //Signal : nFCE nRSTOUT nFRE   nFWE  ALE   CLE  nGCS5 nGCS4 nGCS3 nGCS2 nGCS1 
  54.     //Binary :  1     1      1  , 1   1   1    1   ,  1     1     1     1
  55.     //Ports  : GPA11   GPA10  GPA9   GPA8   GPA7   GPA6   GPA5   GPA4   GPA3   GPA2   GPA1  GPA0
  56.     //Signal : ADDR26 ADDR25 ADDR24 ADDR23 ADDR22 ADDR21 ADDR20 ADDR19 ADDR18 ADDR17 ADDR16 ADDR0 
  57.     //Binary :  1       1      1      1   , 1       1      1      1   ,  1       1     1      1         
  58.     rGPACON = 0x7fffff; 
  59.     //**** PORT B GROUP
  60.     //Ports  : GPB10    GPB9    GPB8    GPB7    GPB6     GPB5    GPB4   GPB3   GPB2     GPB1      GPB0
  61.     //Signal : nXDREQ0 nXDACK0 nXDREQ1 nXDACK1 nSS_KBD nDIS_OFF L3CLOCK L3DATA L3MODE nIrDATXDEN Keyboard
  62.     //Setting: INPUT  OUTPUT   INPUT  OUTPUT   INPUT   OUTPUT   OUTPUT OUTPUT OUTPUT   OUTPUT    OUTPUT 
  63.     //Binary :   00  ,  01       00  ,   01      00   ,  01       01  ,   01     01   ,  01        01  
  64.     rGPBCON = 0x044555;
  65.     rGPBUP  = 0x7ff;     // The pull up function is disabled GPB[10:0]
  66.     //*** PORT C GROUP
  67.     //Ports  : GPC15 GPC14 GPC13 GPC12 GPC11 GPC10 GPC9 GPC8  GPC7   GPC6   GPC5 GPC4 GPC3  GPC2  GPC1 GPC0
  68.     //Signal : VD7   VD6   VD5   VD4   VD3   VD2   VD1  VD0 LCDVF2 LCDVF1 LCDVF0 VM VFRAME VLINE VCLK LEND  
  69.     //Binary :  10   10  , 10    10  , 10    10  , 10   10  , 10     10  ,  10   10 , 10     10 , 10   10
  70.     rGPCCON = 0xaaaaaaaa;       
  71.     rGPCUP  = 0xffff;     // The pull up function is disabled GPC[15:0] 
  72.     //*** PORT D GROUP
  73.     //Ports  : GPD15 GPD14 GPD13 GPD12 GPD11 GPD10 GPD9 GPD8 GPD7 GPD6 GPD5 GPD4 GPD3 GPD2 GPD1 GPD0
  74.     //Signal : VD23  VD22  VD21  VD20  VD19  VD18  VD17 VD16 VD15 VD14 VD13 VD12 VD11 VD10 VD9  VD8
  75.     //Binary : 10    10  , 10    10  , 10    10  , 10   10 , 10   10 , 10   10 , 10   10 ,10   10
  76.     //rGPDCON  = 0xaaa9aaaa;   // GPD8: USB_CHG_DIS: Output
  77.     //rGPDUP   = 0xffff;       // The pull up function is disabled GPD[15:0]
  78.     //rGPDDAT &= ~(0x1 << 8);  // Set USB_CHG_DIS Low
  79.     //Ports  : GPD15        GPD14   GPD13   GPD12   GPD11   GPD10   GPD9    GPD8         
  80.     //Signal : USB_PULLUP   NC      NC      NC      NC      nFWP    SELI    USB_CHG_DIS  
  81.     //CON    : 00           00      00      00      00      01      01      01
  82.     //DAT    : 0            0       0       0       0       1       0(100ma)0 (low)
  83.     //UP     : 1            0       0       0       0       1       1       1
  84.     //Ports  : GPD7         GPD6    GPD5    GPD4    GPD3    GPD2    GPD1    GPD0
  85.     //Signal : NC           EL_EN   KEEPACT IR_SD   PWREN2  NC      TXON    NC
  86.     //CON    : 00           01      01      01      01      00      01      00
  87.     //DAT    : 0            0(on)   1(high) 1(on)   0(low)  0       0(low)  0
  88.     //UP     : 0            1       1       1       1       0       1       0
  89.     rGPDCON  = 0x00151544;
  90.     rGPDDAT  = 0x0430;
  91.     rGPDUP   = 0x877A;
  92.     //*** PORT E GROUP
  93.     //Ports  : GPE15  GPE14 GPE13   GPE12   GPE11   GPE10   GPE9    GPE8     GPE7  GPE6  GPE5   GPE4  
  94.     //Signal : IICSDA IICSCL SPICLK SPIMOSI SPIMISO SDDATA3 SDDATA2 SDDATA1 SDDATA0 SDCMD SDCLK I2SSDO 
  95.     //Binary :  10     10  ,  10      10  ,  00      10   ,  10      10   ,   10    10  , 10     10  ,     
  96.     //-------------------------------------------------------------------------------------------------------
  97.     //Ports  :  GPE3   GPE2  GPE1    GPE0    
  98.     //Signal : I2SSDI CDCLK I2SSCLK I2SLRCK     
  99.     //Binary :  10     10  ,  10      10 
  100.     //rGPECON = 0xaaaaaaaa;       
  101.     //rGPEUP  = 0xffff;     // The pull up function is disabled GPE[15:0]
  102.     rGPECON = 0xaa2aaaaa;       
  103.     rGPEUP  = 0xf7ff;       // GPE11 is NC
  104.     //*** PORT F GROUP
  105.     //Ports  : GPF7   GPF6   GPF5   GPF4      GPF3     GPF2  GPF1   GPF0
  106.     //Signal : nLED_8 nLED_4 nLED_2 nLED_1 nIRQ_PCMCIA EINT2 KBDINT EINT0
  107.     //Setting: Output Output Output Output    EINT3    EINT2 EINT1  EINT0
  108.     //Binary :  01      01 ,  01     01  ,     10       10  , 10     10
  109.     rGPFCON = 0x55aa;
  110.     rGPFUP  = 0xff;     // The pull up function is disabled GPF[7:0]
  111.     //*** PORT G GROUP
  112.     //Ports  : GPG15 GPG14 GPG13 GPG12  GPG11    GPG10    GPG9     GPG8     GPG7      GPG6    
  113.     //Signal : nYPON  YMON nXPON XMON   NC       SDWP     WHEEL_SW WHEEL_A  WHEEL_B   ONE_WIRE
  114.     //Setting: nYPON  YMON nXPON XMON   IN       EINT18   EINT17   ENT16    EINT15    OUTPUT
  115.     //Binary :   11    11 , 11    11  , 00       01    ,  10       10   ,   10        01
  116.     //UP     :   1     1    1     1     0        1        1        1        1         1
  117.     //-----------------------------------------------------------------------------------------
  118.     //Ports  : GPG5       GPG4      GPG3    GPG2    GPG1     GPG0    
  119.     //Signal : NC         LCD_PWREN NC      nSS_SPI JACK_CLK JACK_DATA
  120.     //Setting: IN         LCD_PWRDN IN      nSS0    EINT9    EINT8
  121.     //Binary : 00         11   ,    00      11  ,   10       10
  122.     //UP     : 0          1         0       1       1        1
  123. // Behavior changed from board rev A to rev D. Don't power LCD down.
  124.     
  125.     //*** PORT H GROUP
  126.     //Ports  :  GPH10    GPH9  GPH8 GPH7  GPH6  GPH5 GPH4 GPH3 GPH2 GPH1  GPH0 
  127.     //Signal : CLKOUT1 CLKOUT0 UCLK nCTS1 nRTS1 RXD1 TXD1 RXD0 TXD0 nRTS0 nCTS0
  128.     //Binary :   01   ,  01     10 , 11    11  , 10   10 , 10   10 , 10    10    
  129.     rGPHCON = 0x16faaa;
  130.     rGPHUP  = 0x7ff;    // The pull up function is disabled GPH[10:0]
  131.     //External interrupt will be falling edge triggered. 
  132.     rEXTINT0 = 0x22222222;    // EINT[7:0]
  133.     rEXTINT1 = 0x22222222;    // EINT[15:8]
  134.     rEXTINT2 = 0x22222222;    // EINT[23:16]
  135. }
  136. //***************************[ UART ]******************************
  137. void Uart_Init(void)
  138. {
  139.     int i;
  140.     rUFCON1 = 0x0;      // FIFO disable
  141.     rUMCON1 = 0x0;      // AFC disable
  142.     rULCON1 = 0x3;      // Normal,No parity,1 stop,8 bits
  143.     rUCON1  = 0x245;   
  144.     
  145.     rUBRDIV1=( (int)(PCLK/16./BAUD_RATE) -1 );
  146.     for(i=0;i<100;i++);
  147.     
  148. }
  149. //=====================================================================
  150. void Uart_SendByte(int data)
  151. {
  152.         if(data=='n')
  153.         {
  154.             while(!(UART_STATUS & 0x2));
  155.             Delay(10);                 //because the slow response of hyper_terminal 
  156.             WRITE_UART('r');
  157.         }
  158.         while(!(UART_STATUS & 0x2));   //Wait until THR is empty.
  159.         Delay(10);
  160.         WRITE_UART(data);
  161. }               
  162. //====================================================================
  163. void Uart_SendString(char *pt)
  164. {
  165.     while(*pt)
  166.         Uart_SendByte(*pt++);
  167. }
  168. //====================================================================
  169. void Uart_SendDWORD(DWORD d, BOOL cr)
  170. {
  171.     Uart_SendString("0x");
  172.     Uart_SendString(hex2char((d & 0xf0000000) >> 28));
  173.     Uart_SendString(hex2char((d & 0x0f000000) >> 24));
  174.     Uart_SendString(hex2char((d & 0x00f00000) >> 20));    
  175.     Uart_SendString(hex2char((d & 0x000f0000) >> 16));
  176.     Uart_SendString(hex2char((d & 0x0000f000) >> 12));
  177.     Uart_SendString(hex2char((d & 0x00000f00) >> 8));
  178.     Uart_SendString(hex2char((d & 0x000000f0) >> 4));
  179.     Uart_SendString(hex2char((d & 0x0000000f) >> 0));
  180.     if (cr)
  181.         Uart_SendString("n");
  182. }
  183. //====================================================================
  184. char *hex2char(unsigned int val)
  185. {
  186.     static char str[2];
  187.     str[1]='';
  188.     
  189.     if(val<=9)
  190.         str[0]='0'+val;
  191.     else 
  192.         str[0]=('a'+val-10);
  193.         
  194.     return str;
  195. }
  196. void ChangeClockDivider(int hdivn,int pdivn)
  197. {
  198.      // hdivn,pdivn FCLK:HCLK:PCLK
  199.      //     0,0         1:1:1 
  200.      //     0,1         1:1:2 
  201.      //     1,0         1:2:2
  202.      //     1,1         1:2:4
  203.     rCLKDIVN = (hdivn<<1) | pdivn;    
  204.     
  205.     if(hdivn)
  206.         MMU_SetAsyncBusMode();
  207. //    else 
  208. //      MMU_SetFastBusMode();
  209. }
  210. void ChangeMPllValue(int mdiv,int pdiv,int sdiv)
  211. {
  212.     rMPLLCON = (mdiv<<12) | (pdiv<<4) | sdiv;
  213. }
  214. void Delay(int time)
  215. {
  216.       // time=0: adjust the Delay function by WatchDog timer.
  217.       // time>0: the number of loop time
  218.       // resolution of time is 100us.
  219.     int i;
  220.     for(i=0;i<1000;i++);
  221. }
  222. void Delay100us(int time)
  223. {
  224. while(time)
  225. {
  226.     int i;
  227.     for(i=0;i<1000;i++);
  228.     time--;
  229.     }
  230. }