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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? coffloader.cpp

?? dsp2808控制的代碼
?? CPP
?? 第 1 頁 / 共 4 頁
字號:
	Tmem.Space    = Space;
	Tmem.Asize    = M_SIZE16;
	Tmem.Bsize    = M_SIZE16;
	Tmem.Length   = Count;
	Tmem.pData    = pData;
	if( m_pSdti_Intf->pMem->Write( m_Sdti_Hndl, &Tmem ) == FALSE )
		return( FALSE );

	return( TRUE );
}

/*F***************************************************************************
* NAME: ReadMemory( MEM_TADDR Addr, MEM_SPACE Space, TREG_16 *pData, 
*                    DWORD Count  )
*
* DESCRIPTION:  Read 16 bit data to memory
*
*F***************************************************************************/
BOOL CoffLoader::ReadMemory(  MEM_TADDR Addr, 
							  MEM_SPACE Space, 
							  TREG_16 * pData, 
							  DWORD     Count  )
{
    TMEM_DESC Tmem;

    // Always test for connection to prevent user calling in disconnected
    // state or with NULL handles.
    if( CheckConnection() == FALSE ) {
        return( FALSE );
    }

	Tmem.Taddr    = Addr;
	Tmem.Space    = Space;
	Tmem.Asize    = M_SIZE16;
	Tmem.Bsize    = M_SIZE16;
	Tmem.Length   = Count;
	Tmem.pData    = pData;
	if( m_pSdti_Intf->pMem->Read( m_Sdti_Hndl, &Tmem ) == FALSE )
		return( FALSE );

	return( TRUE );
}

/*F***************************************************************************
* NAME: ReadRegister(  char * RegName, DWORD *pReg );  
*
* DESCRIPTION:  Read register
*
*F***************************************************************************/
BOOL CoffLoader::ReadRegister(  char * RegName, DWORD *pReg )
{
    TREG reg;

    // Always test for connection to prevent user calling in disconnected
    // state or with NULL handles.
    if( CheckConnection() == FALSE ) {
        return( FALSE );
    }

    if ( m_pSdti_Intf->pReg->ReadByName( m_Sdti_Hndl, RegName, &reg ) == FALSE )
		return( FALSE );

    // We treat all registers as 32 bit values even though most are just
    // 16 bit.  The sdti code knows to do the right thing.
    *pReg = reg.Reg32;

	return( TRUE );
}

/*F***************************************************************************
* NAME: WriteRegister(  char * RegName, DWORD *pReg );  
*
* DESCRIPTION:  Write register
*
*F***************************************************************************/
BOOL CoffLoader::WriteRegister(  char * RegName, DWORD *pReg )
{
    TREG reg;
    
    // Always test for connection to prevent user calling in disconnected
    // state or with NULL handles.
    if( CheckConnection() == FALSE ) {
        return( FALSE );
    }

    // We treat all registers as 32 bit values even though most are just
    // 16 bit.  The sdti code knows to do the right thing.

    reg.Reg32 = *pReg;

    if ( m_pSdti_Intf->pReg->WriteByName( m_Sdti_Hndl, RegName, &reg ) == FALSE )
	    return( FALSE );

	return( TRUE );
}


/*F***************************************************************************
* NAME: LoadCoff( )   
*
* DESCRIPTION:  Load coff file to the target and load it's symbol table.
*
*
*F***************************************************************************/
BOOL CoffLoader::LoadCoff( )
{
    TREG      reg;
    CString   entryPoint;
    BOOL      success = FALSE;

    m_coffHndl = NULL;

    // Always test for connection to prevent user calling in disconnected
    // state or with NULL handles.
    if( CheckConnection() == FALSE ) {
        return( FALSE );
    }

    // Error checking of parameters 
    if ( ( !m_pSdti_Intf ) || ( !m_Sdti_Hndl ) )
        return FALSE;

    // Open the file and fetch all coff settings 
    if ( m_coffLib->COFFR_FileOpen( m_coffFileName, &m_coffOpts, &m_coffHndl ) )
    {
        ErrMsg( "ERROR \tFailed to Open Coff File." );
        goto EXIT_COFF_LOAD;
    }

	// Build the symbol table
	BuildSymbolTable();

    // Load raw data onto processor memory 
    success = LoadRawData( );
    if ( success )
    {       
        reg.Reg32 = m_coffHndl->FileInfo->entry_point;

        /* For string formatting purposes */ 
        entryPoint.Format( "%x", reg.Reg32 );

		if ( m_pSdti_Intf->pReg->WriteByName( m_Sdti_Hndl, "PC", &reg ) == FALSE )
			success = FALSE;
        
    }

EXIT_COFF_LOAD:
    // Close the coff file. This could be removed as we will cleanup 
	// in the destructor.
    if ( m_coffHndl )
	{
        m_coffLib->COFFR_FileClose( m_coffHndl );
		m_coffHndl = NULL;
	}
    return success;
}

/*F***************************************************************************
* NAME: LoadRawData( )   
*
* DESCRIPTION:  Load the raw coff data
*
*
*F***************************************************************************/
BOOL CoffLoader::LoadRawData( )
{
    TI_SCNHDR*      pSection_Hdr;
    TMEM_DESC       Tmem;
    unsigned char*  pCoff_Buffer;
    long            coff_buffer_size;

    long            total_byte_size,num_vals;
    int             num_sections;
    short           i;

    BOOL            success = TRUE;
    CString         sectionId;
    CString         entryPoint;
    CString         memAddress;
    CString         memLength;

    // Always test for connection to prevent user calling in disconnected
    // state or with NULL handles.
    if( CheckConnection() == FALSE ) {
        return( FALSE );
    }

    // Coff section size is in target bytes so convert to host bytes 
    coff_buffer_size = m_coffLib->LOCTOBYTE( m_coffHndl, m_coffHndl->FileInfo->largest_sect_size );

    // Allocate memory for coff buffer 
    pCoff_Buffer = ( unsigned char* )new( char[coff_buffer_size] );
    if ( ! pCoff_Buffer )
        return FALSE;

    // Pointer to section header  
    pSection_Hdr = ( TI_SCNHDR* )( m_coffHndl->FileInfo->sect_hdrs );
    num_sections = m_coffHndl->FileInfo->file_hdr.f_nscns;

    Message( "Loading COFF file.\r\n" );
    Message( "Filename:           " + m_coffFileName);
  
	// For string formatting purposes 
    entryPoint.Format( "%x", m_coffHndl->FileInfo->entry_point );
    while ( entryPoint.GetLength() < 8 )
        entryPoint.Insert(0, "0");

    Message( "File entry point:  0x" + entryPoint + "\r\n" );

    // Go through each section to determine if it should be loaded
    for ( i = 1 ; i <= num_sections ; i++, pSection_Hdr++ )
    {
        if ( m_coffLib->COFFR_IsLoadSection( m_coffHndl, i ) != COFF_NOLOADSECT_ERR )
        {
            m_coffLib->COFFR_GetSectData( m_coffHndl, ( short )i, pCoff_Buffer, 0,
                                           m_coffLib->LOCTOBYTE( m_coffHndl, pSection_Hdr->s_size ),
                                           &total_byte_size );

			// Convert to target vals 
			num_vals = m_coffLib->BYTETOLOC(m_coffHndl,total_byte_size);

            // Set parameters to write the section of the coff file 
            Tmem.Taddr  = pSection_Hdr->s_vaddr;
            Tmem.Space  = ( pSection_Hdr->s_page == 0 ) ? M_PROGRAM : M_DATA;
            Tmem.Asize  =  M_SIZE16;
            Tmem.Bsize  =  M_SIZE8; // Our buffer is 8 bit chars for coff
            Tmem.Length = num_vals;
            Tmem.pData  = ( void* )( pCoff_Buffer );

            // Write data to memory 
            if ( ( success = m_pSdti_Intf->pMem->Write( m_Sdti_Hndl, &Tmem ) ) == FALSE )
                break;

        }/* End of COFFR_IsLoadSection */ 
    }

    if ( success == FALSE )
        Message( "\t\t...FAILED." );

    // Free coff buffer
    delete( pCoff_Buffer );
    return success;
}

/*F***************************************************************************
* NAME: BytesPerDataSize(struct SYMBOL * s)  
*
* DESCRIPTION:  Determine the number of bytes for a given symbol type.  Just
*               handles the easy cases.
*
*F***************************************************************************/
int CoffLoader::BytesPerDataSize(struct SYMBOL * s)
{
	switch( s->symtype &0x0f )
	{

		case TI_T_LONG:               /* LONG INTEGER                        */
		case TI_T_ULONG:			  /* UNSIGNED LONG                       */
			return( 4 );

		// Not used in the programamer
		case TI_T_FLOAT:              /* SINGLE PRECISION FLOATING POINT     */
		case TI_T_DOUBLE:             /* DOUBLE PRECISION FLOATING POINT     */
		case TI_T_STRUCT:             /* STRUCTURE                           */
		case TI_T_UNION:              /* UNION                               */
		case TI_T_ENUM:               /* ENUMERATION                         */
		case TI_T_LDOUBLE:            /* LONG DOUBLE FLOATING POINT          */
			return( 0 );

		case TI_T_VOID:               /* VOID TYPE                           */
		case TI_T_SCHAR:              /* CHARACTER (EXPLICITLY "signed")     */
		case TI_T_CHAR:               /* CHARACTER (IMPLICITLY SIGNED)       */
		case TI_T_SHORT:              /* SHORT INTEGER                       */
		case TI_T_INT:                /* INTEGER                             */
		case TI_T_UCHAR:              /* UNSIGNED CHARACTER                  */
		case TI_T_USHORT:             /* UNSIGNED SHORT                      */
		case TI_T_UINT:               /* UNSIGNED INTEGER                    */
		default:
			return( 2 );
	}
}

/*F***************************************************************************
* NAME: FindSymbol(char * name)   
*
* DESCRIPTION:  Search the symbol table for symbol name
*
*
*F***************************************************************************/
struct SYMBOL * CoffLoader::FindSymbol(char * name)
{
   SYMBOL_L * n;

   //Go through list from head to tail - if the name matches, return 
   n = m_symlist;
   while (n != (SYMBOL_L *)NULL )
       {
       if(    (strcmp(name,    n->s->symname) == 0)  // C name  _Symbol
           || (strcmp(name+1,  n->s->symname) == 0)) // asm name Symbol
           break;
       n = n->next;
       }
   if ( n!= (SYMBOL_L *)NULL )
       return ( n->s );
   return ((struct SYMBOL *)NULL );
}
/*F***************************************************************************
* NAME: DeleteSymbolList( void )   
*
* DESCRIPTION:  Delete the symbol table
*
*
*F***************************************************************************/
BOOL CoffLoader::DeleteSymbolList( void )
{
   SYMBOL_L * n;

   while (m_symlist != (SYMBOL_L *)NULL )
   {
	   n = m_symlist->next;
	   delete(m_symlist->s->symname);  m_symlist->s->symname = (char *)NULL;
	   delete(m_symlist->s);           m_symlist->s = (struct SYMBOL *)NULL;
	   delete(m_symlist);
	   m_symlist = n;
   }
   return(TRUE);
}
/*F***************************************************************************
* NAME: BuildSymbolTable( void )   
*
* DESCRIPTION:  Build the symbol table.  This is crude at best but does get
*               job done for such a simple application.
*
*
*F***************************************************************************/
BOOL CoffLoader::BuildSymbolTable( void )
{
    TI_SCNHDR     * pSectionHdr;
    long            SymbolIndex;
    COFF_SYMTYPE    SymbolType; 
    TI_SYMENT       SymbolEntry;
    TI_AUXENT       AuxEntry;
    long            NumSymbolsRead;
	long            NumSymbolsSaved = 0;

    if( m_coffHndl == NULL )
		return( FALSE );

	// Unload old symbols before loading new symbols
	if( m_symlist != NULL ) {
		DeleteSymbolList();
	}

	// Load the string table first
    m_coffLib->COFFR_LoadStrings( m_coffHndl );

    SymbolIndex    = 0;
    NumSymbolsRead = 0;

    while( SymbolIndex < m_coffHndl->FileInfo->file_hdr.f_nsyms )
    {


        m_coffLib->COFFR_GetSymbolTableEntry(  m_coffHndl, 
											   &SymbolIndex,
											   &SymbolType, 
											   &SymbolEntry,
											   &AuxEntry );

        switch( SymbolType )
        {
            case COFF_AUX_TAG:
                SymbolIndex = AuxEntry.x_tag.x_endndx;
                break;

            case COFF_AUX_FILE:
            case COFF_AUX_SECT:
            case COFF_AUX_BB:
            case COFF_AUX_EOS:
                break;

            default:  
            if( SymbolEntry.n_sclass == TI_C_EXT ) // The interesting symbols, globals
            {
                
               char            name[256];
               SYMBOL_L      * new_list_elem;
               struct SYMBOL * new_sym;
               size_t          name_length;
               
               // Only load interesting symbols 
               if (    ( SymbolEntry.n_scnum < 1)
                    || ( SymbolEntry.n_scnum > m_coffHndl->FileInfo->file_hdr.f_nscns))
                    break;

               pSectionHdr = (TI_SCNHDR  *)(m_coffHndl->FileInfo->sect_hdrs);
               pSectionHdr += (SymbolEntry.n_scnum-1);


               m_coffLib->COFFR_GetSymbolName(  m_coffHndl, &SymbolEntry, 256, name );

			   // Allocate a new symbol, and new symbol list element. Add symbol to  
			   // the head of the list                                                
			   new_sym             = (struct SYMBOL *)new( struct SYMBOL );
			   new_list_elem       = (SYMBOL_L *)new( SYMBOL_L );
			   new_list_elem->s    = new_sym;
			   new_list_elem->next = m_symlist;       // New symbol at head of the list 
			   m_symlist           = new_list_elem;

			   // Fill in the name, address, and page info for the symbol.            
			   name_length = (strlen(name)+1);
			   new_sym->symname = (char *)new( char[name_length]);
			   strcpy(new_sym->symname, name);
			   new_sym->symaddr   = (unsigned long)(SymbolEntry.n_value);
			   new_sym->sympage   = (unsigned long)(pSectionHdr->s_page);
			   new_sym->symtype   = (unsigned long)(SymbolEntry.n_type    );
			   new_sym->symsclass = (unsigned long)(SymbolEntry.n_sclass  );
			   new_sym->symnumaux = (unsigned long)(SymbolEntry.n_numaux  );

			   NumSymbolsSaved++;

            } /* End Default */
            break;

        }/* End of switch */
    } /* End of while */

	m_numSymbols = NumSymbolsSaved;
    return( TRUE );
}


/*F***************************************************************************
* NAME: FindSwbp(char * name)   
*
* DESCRIPTION:  Search the bp table for symbol name
*
*
*F***************************************************************************/
SWBP_SYMBOL * CoffLoader::FindSwbp(char * name )
{
   SWBP_SYMBOL * b;
   SYMBOL      * sym;

   //Go through list from head to tail - if the name matches, return 
   b = m_swbplist;
   while (b != (SWBP_SYMBOL *)NULL )
   {
       sym = b->s;
       if(    (strcmp(name,    sym->symname) == 0)  // C name  _Symbol
           || (strcmp(name+1,  sym->symname) == 0)) // asm name Symbol
           break;
       b = b->next;
   }
   
   if ( b!= (SWBP_SYMBOL *)NULL )
       return ( b );

   return ((SWBP_SYMBOL *)NULL );
}
/*F***************************************************************************
* NAME: DeleteSwbpList( void )   
*
* DESCRIPTION:  Delete the bp table table
*
*
*F***************************************************************************/
BOOL CoffLoader::DeleteSwbpList( void )
{
   SWBP_SYMBOL * b;

   while (m_swbplist != (SWBP_SYMBOL *)NULL )
   {
	   b = m_swbplist->next;
	   delete(m_swbplist);

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产99精品视频| 色素色在线综合| 一区二区三区在线高清| 欧美一区二区三区在| 国产aⅴ综合色| 午夜视频在线观看一区二区| 国产午夜精品久久久久久久| 欧美丰满少妇xxxbbb| eeuss鲁片一区二区三区在线看| 日韩国产欧美三级| 亚洲少妇屁股交4| 精品国产电影一区二区| 欧美日韩久久不卡| 99re热这里只有精品免费视频| 九色综合狠狠综合久久| 亚洲韩国精品一区| 一区精品在线播放| 精品第一国产综合精品aⅴ| 欧美日韩精品是欧美日韩精品| 不卡的电视剧免费网站有什么| 日韩高清在线观看| 亚洲一区二区三区四区在线免费观看 | 亚洲成a人v欧美综合天堂下载 | 夜夜揉揉日日人人青青一国产精品 | 日本成人在线网站| 亚洲黄一区二区三区| 国产欧美日韩中文久久| 精品欧美一区二区在线观看| 91精品国产色综合久久不卡电影| 欧美午夜精品一区二区蜜桃| 91色.com| 91在线你懂得| 99久久综合99久久综合网站| 国产福利91精品| 国产福利一区二区三区视频| 国精产品一区一区三区mba视频| 日本中文字幕一区| 香蕉久久夜色精品国产使用方法| 一区二区三区av电影| 亚洲精品国产第一综合99久久| 亚洲人成精品久久久久| 亚洲视频在线一区二区| 亚洲日本免费电影| 伊人性伊人情综合网| 亚洲精品免费电影| 亚洲国产精品一区二区久久恐怖片| 亚洲欧美另类在线| 亚洲精品午夜久久久| 洋洋成人永久网站入口| 亚洲线精品一区二区三区| 香蕉av福利精品导航| 日日欢夜夜爽一区| 蜜桃视频一区二区三区| 另类调教123区| 九九视频精品免费| 国产精品77777竹菊影视小说| 国产精品一品二品| 99久久精品情趣| 欧洲一区在线电影| 制服丝袜中文字幕一区| 日韩精品中文字幕一区| 久久九九久精品国产免费直播| 国产女人18水真多18精品一级做| 中文字幕一区三区| 亚洲午夜一二三区视频| 日日夜夜精品视频天天综合网| 日本成人在线一区| 国产精品1区2区| 91亚洲精品一区二区乱码| 欧美写真视频网站| 欧美一区二区成人6969| 日本一区二区三区久久久久久久久不 | 精品国产伦一区二区三区观看体验 | 91.麻豆视频| 久久综合中文字幕| 亚洲欧美自拍偷拍色图| 午夜精品一区二区三区电影天堂 | 天天亚洲美女在线视频| 久久99国内精品| 色综合天天性综合| 欧美一卡在线观看| 欧美国产日本视频| 日韩中文字幕1| 丁香婷婷综合五月| 4438x成人网最大色成网站| 亚洲国产岛国毛片在线| 午夜精品福利一区二区三区av| 国产麻豆精品一区二区| 欧美亚洲国产一区二区三区va| 精品免费视频一区二区| 亚洲女性喷水在线观看一区| 久久疯狂做爰流白浆xx| 日本韩国欧美三级| 国产亚洲成年网址在线观看| 五月天久久比比资源色| 国产成人精品一区二| 欧美老肥妇做.爰bbww视频| 国产精品视频在线看| 美国十次了思思久久精品导航| 99视频精品全部免费在线| 精品国产乱码久久久久久夜甘婷婷 | 99久久99久久免费精品蜜臀| 日韩欧美一级二级三级 | 狠狠色狠狠色综合| 欧美午夜电影网| 国产精品视频一二| 激情综合网最新| 69p69国产精品| 一区二区三区不卡在线观看| 国产成人综合在线| 欧美电影免费观看高清完整版在线 | 国模冰冰炮一区二区| 欧美亚洲国产怡红院影院| 国产精品婷婷午夜在线观看| 久久精品av麻豆的观看方式| 欧美人伦禁忌dvd放荡欲情| 亚洲欧美国产高清| 成人夜色视频网站在线观看| 亚洲精品在线网站| 久久精品国产亚洲a| 欧美高清性hdvideosex| 亚洲午夜视频在线观看| 色久优优欧美色久优优| 亚洲视频网在线直播| 99久久亚洲一区二区三区青草| 国产网站一区二区| 国产精品69毛片高清亚洲| 久久综合久久鬼色| 韩国一区二区在线观看| 精品成人a区在线观看| 久久成人av少妇免费| 日韩欧美一二三| 蜜桃视频在线观看一区二区| 日韩欧美专区在线| 奇米一区二区三区| 日韩一区二区免费在线电影| 免费在线成人网| 制服丝袜亚洲色图| 青青草97国产精品免费观看| 欧美一区二区久久久| 久久国产麻豆精品| 久久综合久久鬼色| 成人v精品蜜桃久久一区| 国产精品久久久久久福利一牛影视 | 欧美影院一区二区| 亚洲福利视频三区| 日韩三级伦理片妻子的秘密按摩| 日本美女一区二区三区| 精品国产三级电影在线观看| 国产一区二区女| 国产精品护士白丝一区av| 色综合网站在线| 舔着乳尖日韩一区| 日韩精品一区二区在线观看| 国产成人精品影院| 亚洲精品日韩一| 3d成人h动漫网站入口| 国产在线精品视频| 中文在线资源观看网站视频免费不卡| 高清成人在线观看| 一区二区三区国产精华| 在线播放91灌醉迷j高跟美女| 另类人妖一区二区av| 欧美高清在线一区二区| 色综合久久中文综合久久牛| 天堂久久一区二区三区| 久久亚洲二区三区| 色偷偷成人一区二区三区91| 日韩高清一区二区| 中文字幕第一区| 欧美日韩黄视频| 激情五月婷婷综合网| 亚洲三级电影网站| 欧美一区二区三区小说| 国产69精品久久久久毛片| 亚洲大尺度视频在线观看| 欧美一区二区成人| av一区二区久久| 日韩黄色一级片| 中文字幕av免费专区久久| 欧美日韩久久一区| 盗摄精品av一区二区三区| 亚洲chinese男男1069| 久久久精品国产免大香伊| 色综合亚洲欧洲| 国产精品996| 水野朝阳av一区二区三区| 国产精品美女久久久久久久| 欧美一区二区三区啪啪| av在线不卡免费看| 男女视频一区二区| 一区二区三区高清在线| 国产日韩欧美高清| 欧美一区二区三区四区视频| 99v久久综合狠狠综合久久| 韩国理伦片一区二区三区在线播放 | 在线不卡一区二区| 99re这里只有精品6| 国产精品亚洲а∨天堂免在线| 亚洲电影一区二区|