亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? dec6713.gel

?? 錄DEC6713的UART串口的測試程序。需要將板上的跳針JP3、JP5各自短接
?? GEL
字號:
/*--------------------------------------------------------------*/
/* DEC6713.gel                                                  */
/* version 1.00                                                 */
/*                                                              */
/* This GEL file is designed to be used in conjunction with     */
/* CCS 2.21 and the TMS320C6713 DSP based DEC.                  */
/*                                                              */
/*--------------------------------------------------------------*/

/*--------------------------------------------------------------*/
/* The StartUp() function is called each time CCS is started.   */
/* Customize this function to perform desired initialization.   */
/*--------------------------------------------------------------*/

StartUp()
{
    setup_memory_map(); 
    GEL_Reset();  
    init_emif();
} 

/*--------------------------------------------------------------*/
/* Setup memory map for C6713 DEC.                              */
/*                                                              */
/*--------------------------------------------------------------*/
setup_memory_map()
{
	
	GEL_MapOn();            
	GEL_MapReset();         
	
	/* On-chip memory map */
	GEL_MapAdd(0x00000000,0,0x00030000,1,1); /* Internal RAM (L2) mem    */
	GEL_MapAdd(0x01800000,0,0x00000024,1,1); /* EMIF control regs        */
	GEL_MapAdd(0x01840000,0,0x00000004,1,1); /* Cache configuration reg  */
	GEL_MapAdd(0x01844000,0,0x00000020,1,1); /* L2 base addr & count regs*/
	GEL_MapAdd(0x01844020,0,0x00000020,1,1); /* L1 base addr & count regs*/
	GEL_MapAdd(0x01845000,0,0x00000008,1,1); /* L2 flush & clean regs    */
	GEL_MapAdd(0x01848200,0,0x00000010,1,1); /* CE0 mem attribute regs   */
	GEL_MapAdd(0x01848240,0,0x00000010,1,1); /* CE1 mem attribute regs   */
	GEL_MapAdd(0x01848280,0,0x00000010,1,1); /* CE2 mem attribute regs   */
	GEL_MapAdd(0x018482c0,0,0x00000010,1,1); /* CE3 mem attribute regs   */
	GEL_MapAdd(0x01880000,0,0x00000004,1,1); /* HPI control reg          */
	GEL_MapAdd(0x018c0000,0,0x00000028,1,1); /* McBSP0 regs              */
	GEL_MapAdd(0x01900000,0,0x00000028,1,1); /* McBSP1 regs              */
	GEL_MapAdd(0x01940000,0,0x0000000c,1,1); /* Timer0 regs              */
	GEL_MapAdd(0x01980000,0,0x0000000c,1,1); /* Timer1 regs              */
	GEL_MapAdd(0x019c0000,0,0x0000000c,1,1); /* Interrupt selector regs  */
	GEL_MapAdd(0x019c0200,0,0x00000004,1,1); /* Device configuration     */

	GEL_MapAdd(0x01a00000,0,0x00000800,1,1); /* EDMA parameter RAM       */
	GEL_MapAdd(0x01a0ffe0,0,0x00000020,1,1); /* EDMA control regs        */ 

	GEL_MapAdd(0x01b00000,0,0x0000002b,1,1); /* GPIO                     */ 
	GEL_MapAdd(0x01b40000,0,0x0000003c,1,1); /* I2C0                     */ 
	GEL_MapAdd(0x01b44000,0,0x0000003c,1,1); /* I2C1                     */ 	
	GEL_MapAdd(0x01b4c000,0,0x00000300,1,1); /* McASP0                   */ 	
	GEL_MapAdd(0x01b50000,0,0x00000300,1,1); /* McASP1                   */ 	
	GEL_MapAdd(0x01b7c000,0,0x00000128,1,1); /* PLL                      */ 			
	
	GEL_MapAdd(0x01bc0000,0,0x00000050,1,1);   /********cTools*********/
	GEL_MapAdd(0x02000000,0,0x00000014,0,1); /* QDMA regs                */
	GEL_MapAdd(0x02000020,0,0x00000014,0,1); /* QDMA pseudo-regs         */
	GEL_MapAdd(0x30000000,0,0x04000000,1,1); /* McBSP0 data              */
	GEL_MapAdd(0x34000000,0,0x04000000,1,1); /* McBSP1 data              */
	
	GEL_MapAdd(0x3c000000,0,0x04000000,1,1); /* McASP0 data              */
	GEL_MapAdd(0x3c100000,0,0x04000000,1,1); /* McASP1 data              */ 
	
	/* Off-chip memory map */
	GEL_MapAdd(0x80000000,0,0x01000000,1,1); /* CE0, SDRAM, 16 MBytes    */
	GEL_MapAdd(0x90000000,0,0x00040000,1,1); /* CE1, 8-bit ROM, 128KBytes*/
	//GEL_MapAdd(0x90080000,0,0x00000008,1,1); /* CE1, 8-bit I/O port      */
	GEL_MapAdd(0xA0000000,0,0x10000000,1,1); /* CE2 - SBSRAM	         */
	GEL_MapAdd(0xB0000000,0,0x10000000,1,1); /* CE3 - Daughtercard       */
}

/*--------------------------------------------------------------*/
/* CPLD DEFINITIONS	                                        */
/*--------------------------------------------------------------*/
//#define DEC6713_CTL_REG         0xB0000000
//#define DEC6713_INTSTAT_REG     0xB0000001
//#define DEC6713_STAT_REG        0xB0000002
//#define DEC6713_WDT_REG         0xB0000003

/*#define Get_Board_Rev     ((*(char *)CPLD_REV) & 0x07)
#define Get_Cpld_Rev      ((*(char *)CPLD_REV>>4) & 0x0F)
#define Get_Switches      ((*(char *)CPLD_STAT>>4) & 0x0F)
#define LED0_on           *(char *)CPLD_STAT = 0x01
#define LED1_on           *(char *)CPLD_STAT = 0x02
#define LED2_on           *(char *)CPLD_STAT = 0x04
#define LED3_on           *(char *)CPLD_STAT = 0x08
#define LEDs_off          *(char *)CPLD_STAT = 0x00*/

/*--------------------------------------------------------------*/
/* init_emif() 		                                        */
/*--------------------------------------------------------------*/
init_emif()
{
	#define EMIF_GCTL       0x01800000
	#define EMIF_CE1        0x01800004
	#define EMIF_CE0        0x01800008
	#define EMIF_CE2        0x01800010
	#define EMIF_CE3        0x01800014
	#define EMIF_SDRAMCTL   0x01800018
	#define EMIF_SDRAMTIM   0x0180001C
	#define EMIF_SDRAMEXT   0x01800020
	#define EMIF_CCFG       0x01840000;  /* Cache configuration register */
	
	/* EMIF setup */
	*(int *)EMIF_GCTL     = 0x00000068;
	*(int *)EMIF_CE0      = 0xffffbf33;  /* CE0 SDRAM                     */
	*(int *)EMIF_CE1      = 0x02208802;  /* CE1 Flash 16-bit               */
	*(int *)EMIF_CE2      = 0x22a28a22;  /* CE2 Daughtercard 32-bit async */
	*(int *)EMIF_CE3      = 0x02258802;  /* CE3 Daughtercard 32-bit async */

    //if (Get_Board_Rev == 2)
   // {
	    *(int *)EMIF_SDRAMCTL = 0x57115000;  /* SDRAM control (16 Mb)     */
//	} else
//	{
//	    *(int *)EMIF_SDRAMCTL = 0x47115000;  /* SDRAM control (8 Mb)      */
//	}
	*(int *)EMIF_SDRAMTIM = 0x00000578;  /* SDRAM timing (refresh)        */
	*(int *)EMIF_SDRAMEXT = 0x000a8529;  /* SDRAM Extension register      */
}
 
/*--------------------------------------------------------------*/
/* clear_memory_map()                                           */
/*--------------------------------------------------------------*/
clear_memory_map()
{
    GEL_MapOff();
}

/*--------------------------------------------------------------*/
/* FlushCache()                                                 */
/*--------------------------------------------------------------*/
FlushCache()   
{ 
    /* Invalidate L1P and L1D */
    *(int *)0x01840000 = (*(int *)0x01840000 | 0x00000300);  

    /* Clean L2 */
    *(int *)0x01845004 = 0x1;
}   

/*--------------------------------------------------------------*/
/* OnReset()                                                    */
/*--------------------------------------------------------------*/

OnReset(int nErrorCode)
{
	/* A debugger reset or GEL_Reset() does NOT reset the C6713
	* pll. Uncomment the following line if you want your pll
	* reset.
	*/
	/*reset_pll(); */
	init_emif();
}

/*--------------------------------------------------------------*/
/* OnPreFileLoaded()                                            */
/* This function is called automatically when the 'Load Program'*/
/* Menu item is selected.                                       */
/*--------------------------------------------------------------*/
OnPreFileLoaded()
{
/*	GEL_Reset(); 	 -- Commented out for CCS 2.20 */
	FlushCache(); 
	IER = 0;
	IFR = 0;
	init_emif();
}


/*--------------------------------------------------------------*/
/* OnRestart()                                                  */
/* This function is called by CCS when you do Debug->Restart.   */
/* The goal is to put the C6x into a known good state with      */
/* respect to cache, edma and interrupts.                       */
/* Failure to do this can cause problems when you restart and   */
/* run your application code multiple times.  This is different */
/* then OnPreFileLoaded() which will do a GEL_Reset() to get the*/
/* C6x into a known good state.                                 */
/*--------------------------------------------------------------*/
OnRestart(int nErrorCode )
{

      /* Turn off L2 for all EMIFA CE spaces.  App should
      *  manage these for coherancy in the application.
      *  GEL_TextOut("Turn off cache segment\n");
      */
      *(int *)0x1848200 = 0;  /* MAR0 */
      *(int *)0x1848204 = 0;  /* MAR1 */
      *(int *)0x1848208 = 0;  /* MAR2 */
      *(int *)0x184820c = 0;  /* MAR3 */
      
      /* Disable EDMA events and interrupts and clear any
      *  pending events.
      *  GEL_TextOut("Disable EDMA event\n");  
      */               
      *(int *)0x01A0FFE8 = 0;          /* CIERL */           
      *(int *)0x01A0FFF4 = 0;          /* EERL */
      *(int *)0x01A0FFF8 = 0xFFFFFFFF; /* ECRL */
      
      /* Disable other interrupts */
      IER = 0;
      IFR = 0;
}	

/*--------------------------------------------------------------*/
/* RESET MENU                                                   */
/*--------------------------------------------------------------*/ 
menuitem "Resets";

hotmenu ClearBreakPts_Reset_EMIFset()
{
	GEL_BreakPtReset();
	GEL_Reset();
	init_emif();
} 

hotmenu Flush_Cache() 
{ 
	FlushCache();
} 

hotmenu ResetPll()
{
	reset_pll();
}

hotmenu InitPll()
{
	init_pll();
}

hotmenu InitCpld()
{
	init_cpld();
}

/*--------------------------------------------------------------*/
/* MEMORY MAP MENU                                              */
/*--------------------------------------------------------------*/ 
menuitem "Memory Map";

hotmenu SetMemoryMap()
{
	setup_memory_map();
}

hotmenu ClearMemoryMap()
{
	clear_memory_map();
}

/*--------------------------------------------------------------*/
/* C6713 PLL SUPPORT                                            */
/*--------------------------------------------------------------*/
#define PLL_BASE_ADDR   0x01b7c000
#define PLL_PID         ( PLL_BASE_ADDR + 0x000 )
#define PLL_CSR         ( PLL_BASE_ADDR + 0x100 )
#define PLL_MULT        ( PLL_BASE_ADDR + 0x110 )
#define PLL_DIV0        ( PLL_BASE_ADDR + 0x114 )
#define PLL_DIV1        ( PLL_BASE_ADDR + 0x118 )
#define PLL_DIV2        ( PLL_BASE_ADDR + 0x11C )
#define PLL_DIV3        ( PLL_BASE_ADDR + 0x120 )
#define PLL_OSCDIV1     ( PLL_BASE_ADDR + 0x124 )

#define CSR_PLLEN          0x00000001
#define CSR_PLLPWRDN       0x00000002
#define CSR_PLLRST         0x00000008 
#define CSR_PLLSTABLE      0x00000040
#define DIV_ENABLE         0x00008000

reset_pll()
{
	/* Set the PLL back to power on reset state*/
    *(int *)PLL_CSR     = 0x00000048;
    *(int *)PLL_DIV3    = 0x00008001;
    *(int *)PLL_DIV2    = 0x00008001;
    *(int *)PLL_DIV1    = 0x00008000;
    *(int *)PLL_DIV0    = 0x00008000;
    *(int *)PLL_MULT    = 0x00000007;
    *(int *)PLL_MULT    = 0x00000007;
    *(int *)PLL_OSCDIV1 = 0x00080007;           
}

init_pll()
{
    /* When PLLEN is off DSP is running with CLKIN clock source,
    * currently 50MHz or 20ns clk rate.
    */
    *(int *)PLL_CSR  &= ~CSR_PLLEN;

    /* Reset the pll.  PLL takes 125ns to reset.    */
    *(int *)PLL_CSR  |= CSR_PLLRST;

    /* PLLOUT = CLKIN/(DIV0+1) * PLLM
    * 450    = 50/1 * 9
    */ 
    *(int *)PLL_DIV0    = DIV_ENABLE + 0;  
    *(int *)PLL_MULT    = 18;               


    *(int *)PLL_OSCDIV1 = DIV_ENABLE + 4;

    /* Program in reverse order. 
    *  DSP requires that pheriheral clocks be less then
    *  1/2 the CPU clock at all times.
    */

    *(int *)PLL_DIV3    = DIV_ENABLE + 4; 

    *(int *)PLL_DIV2    = DIV_ENABLE + 3; 

    *(int *)PLL_DIV1    = DIV_ENABLE + 1; 
    
    *(int *)PLL_CSR  &= ~CSR_PLLRST;

	/* Now enable pll path and we are off and running at 225MHz
	* with 90 MHz SDRAM.
	*/
    *(int *)PLL_CSR |= CSR_PLLEN;

}

/*--------------------------------------------------------------*/
/* LED_cycle()                                                  */
/*--------------------------------------------------------------*/
/*LED_cycle()
{
	LED3_on;
	LED2_on;
	LED1_on;
	LED2_on;
	LED3_on;
	LEDs_off;
} */ 

/*--------------------------------------------------------------*/
/* init_cpld() - Set CPLD to default state                      */
/*--------------------------------------------------------------*/
init_cpld()
{

	*(char*)DEC6713_CTL_REG = 0;
	//*(char*)CPLD_DC   = 0;
	//*(char*)CPLD_MISC = 0;
}
		
/*--------------------------------------------------------------*/
/* MEMORY MAP MENU                                              */
/*--------------------------------------------------------------*/ 
/*menuitem "Check DSK";
hotmenu QuickTest()
{
	LED_cycle();
	LED_cycle();
	LED_cycle();
	GEL_TextOut(" Switches: %d  Board Revision: %d CPLD Revision: %d\n\n","DSKOutput",1,1,1,
	              Get_Switches, Get_Board_Rev, Get_Cpld_Rev);	
}*/

menuitem "SEED-DEC6713 UART CHANNEL SELECT";

hotmenu UART_A_CHANNEL_SELECT()
{
	*(unsigned char *)(0x20000) = 0x01;		
}

hotmenu UART_B_CHANNEL_SELECT()
{
	*(unsigned char *)(0x20000) = 0x02;		
}

hotmenu UART_AB_CHANNEL_SELECT()
{
	*(unsigned char *)(0x20000) = 0x03;		
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久电影国产免费久久电影| 成人黄色一级视频| 欧美经典一区二区| 欧美三区免费完整视频在线观看| 国产美女在线精品| 午夜亚洲福利老司机| 国产精品美女久久久久高潮| 欧美一级视频精品观看| 不卡一区二区在线| 国产精品自拍三区| 毛片基地黄久久久久久天堂| 一区二区三区影院| 国产精品国产自产拍高清av王其| 日韩欧美亚洲一区二区| 欧美视频一区二区在线观看| eeuss鲁一区二区三区| 国内成人免费视频| 免费观看在线综合色| 亚洲图片欧美色图| 1区2区3区精品视频| 久久久久久夜精品精品免费| 91麻豆精品国产| 在线精品视频免费播放| 99久精品国产| 不卡一区在线观看| 国产精品一区二区在线看| 免费xxxx性欧美18vr| 天天综合色天天综合色h| 一区二区三区自拍| 亚洲女人****多毛耸耸8| 中文字幕亚洲成人| 中文字幕亚洲视频| 亚洲视频免费看| 国产精品久久毛片av大全日韩| 国产午夜精品在线观看| 精品国产乱码久久久久久久久| 7777女厕盗摄久久久| 777久久久精品| 欧美一区二区性放荡片| 91精品欧美久久久久久动漫| 欧美精品在线视频| 欧美一区二区三区在线观看视频| 欧美无人高清视频在线观看| 欧美色图一区二区三区| 欧美日韩一区二区三区四区| 欧美日本乱大交xxxxx| 欧美一区二区三区爱爱| 日韩视频123| 久久嫩草精品久久久精品一| 国产亚洲欧美日韩在线一区| 日本一区二区动态图| 国产精品色哟哟| 亚洲蜜桃精久久久久久久| 亚洲制服欧美中文字幕中文字幕| 午夜精品影院在线观看| 天堂久久久久va久久久久| 免费成人性网站| 国产美女精品一区二区三区| 成人va在线观看| 91社区在线播放| 欧美精品aⅴ在线视频| 日韩一区二区麻豆国产| 久久久久久久免费视频了| 欧美经典一区二区三区| 亚洲精品美国一| 秋霞国产午夜精品免费视频| 国产一区在线精品| 色综合夜色一区| 91精品婷婷国产综合久久性色| 日韩久久免费av| 国产精品青草久久| 亚洲第一在线综合网站| 激情综合色播激情啊| gogogo免费视频观看亚洲一| 欧美日韩精品电影| 久久精品人人爽人人爽| 一区二区三区精品视频在线| 久久国产乱子精品免费女| 成人在线综合网| 欧美性xxxxx极品少妇| 精品久久一区二区三区| 亚洲欧洲99久久| 蜜臀精品一区二区三区在线观看 | 国产一区在线视频| 日本韩国欧美国产| 精品日韩在线一区| 亚洲乱码国产乱码精品精可以看 | 精品在线亚洲视频| 成年人国产精品| 欧美成人一级视频| 一区二区三区在线观看视频| 国产真实乱偷精品视频免| 在线看不卡av| 国产精品三级在线观看| 午夜a成v人精品| 成人18精品视频| 精品国产乱码久久久久久影片| 亚洲一区自拍偷拍| 国产91在线看| 日韩精品专区在线影院重磅| 一片黄亚洲嫩模| 成人免费的视频| 精品久久一区二区三区| 午夜a成v人精品| 97se亚洲国产综合在线| 久久九九久久九九| 日韩av电影免费观看高清完整版在线观看 | 欧美自拍偷拍一区| 日本一区二区高清| 精品写真视频在线观看| 欧美疯狂性受xxxxx喷水图片| 国产精品久久久一本精品 | 免费成人av在线| 欧美性大战久久久| 亚洲欧美日韩精品久久久久| 国产精品一区二区在线观看不卡| 日韩一级完整毛片| 午夜精品久久久久久久久久| 91黄色免费观看| 中文字幕欧美一| 不卡一区中文字幕| 中文字幕av一区二区三区高| 国产精品亚洲第一| 2023国产精品自拍| 老司机午夜精品| 91精品国产91久久久久久最新毛片 | 蜜桃91丨九色丨蝌蚪91桃色| 欧美日本一道本| 天堂在线一区二区| 欧美日韩国产一级片| 亚洲国产一二三| 欧美午夜在线观看| 亚洲在线免费播放| 欧美日韩中文字幕一区| 亚洲高清免费一级二级三级| 欧美三级电影精品| 午夜视频一区二区三区| 欧美一区二区三区在线看| 日韩精品1区2区3区| 欧美一区二区视频在线观看2020 | 成人免费看视频| 国产精品高潮久久久久无| 99riav一区二区三区| 亚洲青青青在线视频| 91福利精品视频| 亚洲午夜久久久久久久久电影院| 欧美伊人久久久久久久久影院 | 日韩美女视频在线| 久久97超碰色| 国产亚洲一区二区在线观看| 国产成人精品免费一区二区| 国产精品午夜免费| 99riav久久精品riav| 亚洲午夜三级在线| 日韩一区二区免费在线观看| 国模少妇一区二区三区| 国产人久久人人人人爽| 97精品国产97久久久久久久久久久久| 一区二区三区在线观看动漫| 欧美人成免费网站| 久草中文综合在线| 中文字幕第一页久久| 91极品视觉盛宴| 久久精工是国产品牌吗| 亚洲国产精品成人综合| 色成年激情久久综合| 日本va欧美va瓶| 欧美韩日一区二区三区四区| 色呦呦国产精品| 日韩电影在线观看一区| 国产亚洲视频系列| 欧美中文字幕一区| 国产在线一区二区综合免费视频| 亚洲欧美综合另类在线卡通| 欧美美女直播网站| 国产成人在线影院| 亚洲一区自拍偷拍| 久久亚洲精华国产精华液| 99国产精品久| 极品少妇一区二区三区精品视频 | 久久九九久久九九| 日本韩国一区二区| 国产一区福利在线| 一区二区三区美女视频| 精品国产自在久精品国产| 91丨九色丨蝌蚪丨老版| 免费在线看成人av| 亚洲欧洲中文日韩久久av乱码| 91精品国产欧美一区二区| av亚洲精华国产精华精华| 蜜桃精品视频在线观看| 亚洲欧美激情小说另类| 精品福利av导航| 欧美日韩一区三区四区| 成人av综合一区| 久久电影网站中文字幕| 亚洲综合成人在线| 国产精品午夜久久| 精品久久久影院| 7777精品伊人久久久大香线蕉的 |