WinCE开机Logo的实现(USB下载图片到nandflash)

转载 2015年07月10日 17:51:14

WinCE开机启动Logo使用Eboot读取NandFlash中的图片数据,然后显示的方式。对于开机logo的方式网友http://jazka.blog.51cto.com/809003/664131有了详细的描述。但是自己在运用的时候遇到了一些问题。现在重新进行整理。

在loader.h中增加保留的block提供给图片用。

  1. #define LOGO_BLOCK              8  
  2. #define LOGO_SECTOR_SIZE            FILE_TO_SECTOR_SIZE(LOGO_RAM_IMAGE_SIZE)  
  3. #define LOGO_BLOCK_SIZE             8//SECTOR_TO_BLOCK(LOGO_SECTOR_SIZE)  
  4. #define LOGO_SECTOR             BLOCK_TO_SECTOR(LOGO_BLOCK)  
  5. /* 
  6. #define CONFIG_BLOCK            16 
  7. #define  CONFIG_BLOCK_SIZE      1 
  8. #define  CONFIG_SECTOR          BLOCK_TO_SECTOR(CONFIG_BLOCK) 
  9. */  
  10. #define RESERVED_BOOT_BLOCKS            (NBOOT_BLOCK_SIZE + TOC_BLOCK_SIZE + EBOOT_BLOCK_SIZE + LOGO_BLOCK_SIZE )  

main.c中的MainMenu函数中增加通过USB下载图片的菜单

  1. case 'G':  
  2. case 'g':  
  3.                  
  4. {  
  5.     DWORD dwDWNAddress;  
  6.     DWORD dwDWNlength;  
  7.     DWORD i;  
  8.     BYTE Temp[10];    
  9.     DWORD dwStartAddr = 0;   
  10.     LPBYTE lpDes = NULL;      
  11.     lpDes = (LPBYTE)(FILE_CACHE_START);   
  12.      
  13.         OALMSG(TRUE, (TEXT("Please send the Logo through USB.\r\n")));   
  14.         g_bUSBDownload = TRUE;     
  15. <span style="white-space:pre">  </span>if (!OEMReadData (sizeof (DWORD), (LPBYTE) &dwDWNAddress) ||  
  16.             !OEMReadData (sizeof (DWORD), (LPBYTE) &dwDWNAddress) ||  
  17.             !OEMReadData (sizeof (DWORD), (LPBYTE) &dwDWNlength))  
  18.     {  
  19.     <span style="white-space:pre">  </span>KITLOutputDebugString ("\r\nUnable to read add + size message.\r\n");  
  20.         return (FALSE);  
  21.     }  
  22.     else  
  23.     {  
  24.     <span style="white-space:pre">  </span>KITLOutputDebugString ("\rAddr: 0x%x ; Size: 0x%x\n",dwDWNAddress,dwDWNlength);  
  25.     }  
  26.   
  27.         if (!OEMReadData(640*480*2, lpDes))  
  28.         {   
  29.         <span style="white-space:pre">  </span>OALMSG(TRUE, (TEXT("Error when sending the Logo through USB.\r\n")));   
  30.                 SpinForever();   
  31.         }   
  32.         for( i=0; i<20; i++)  
  33.               <span style="white-space:pre">    </span>OALMSG(0, (TEXT("->0x%x\r\n"),*(lpDes+(640*480*2-10)+i)));  
  34.   
  35.         dwStartAddr = (DWORD)lpDes;   
  36.   
  37.         if (!WriteLogoToBootMedia(dwStartAddr, (DWORD)(640*480*2), dwStartAddr))   
  38.         {   
  39.         <span style="white-space:pre">  </span>OALMSG(TRUE, (TEXT("Error when WriteLogoToBootMedia.\r\n")));   
  40.                 SpinForever();   
  41.         }   
  42.     break;  
  43. }  
在OEMPlatformInit()函数初始化LCD完成之后进行读取NandFlash中的数据进行显示,EXT_Logo()函数在nand.cpp中

  1. void    EXT_Logo(void)  
  2. {  
  3.     SectorInfo si;  
  4.     DWORD i,j,k;  
  5.     UINT32 start_addr = 0x100000;  
  6.   
  7.     k =     start_addr >> 9;  
  8.   
  9.     for (i=0;i<2048;i++)  
  10.     {      
  11.         j = i + k;  
  12.         FMD_ReadSector(j, (PUCHAR)(IMAGE_FRAMEBUFFER_UA_BASE_eboot+(512*i)), &si, 1);   
  13.     }  
  14.   
  15. }  


在Nand.cpp中添加写图片数据到NandFlash的函数WriteLogoToBootMedia()

  1. BOOL WriteLogoToBootMedia(DWORD dwImageStart, DWORD dwImageLength, DWORD dwLaunchAddr)   
  2. {   
  3.   DWORD dwBlock,dwNumBlocks;   
  4.   LPBYTE pbBuffer;   
  5.   SectorInfo si;   
  6.   
  7.   OALMSG(TRUE, (TEXT("+WriteLogoToBootMedia\r\n")));   
  8.   
  9.   dwBlock = LOGO_BLOCK;   
  10.   pbBuffer = (LPBYTE)dwImageStart;   
  11.   
  12.   OALMSG(0, (TEXT("^^^^^^^^ 0x%x ^^^^^^^^\r\n"), (unsigned short *)pbBuffer));   
  13.   
  14.   dwNumBlocks = (dwImageLength/(g_FlashInfo.wDataBytesPerSector*g_FlashInfo.wSectorsPerBlock)) +      
  15.                                                  (dwImageLength%(g_FlashInfo.wDataBytesPerSector*g_FlashInfo.wSectorsPerBlock) ? 1: 0);   
  16.   
  17.   OALMSG(0, (TEXT("dwImageLength = 0x%x \r\n"), dwImageLength)); // 600k = 640 * 480 * 2  
  18.   OALMSG(0, (TEXT("dwNumBlocks = 0x%x \r\n"), dwNumBlocks));  //     5 = 600 /128  
  19.   
  20.   while (dwNumBlocks--)   
  21.   {   
  22.     OALMSG(0, (TEXT("dwBlock(0x%x) X "), dwBlock)); // 8, 9, a, b, c  
  23.     OALMSG(0, (TEXT("g_FlashInfo.wSectorsPerBlock(0x%x)"), g_FlashInfo.wSectorsPerBlock)); // 64  
  24.     OALMSG(0, (TEXT(" = 0x%x \r\n"), dwBlock*g_FlashInfo.wSectorsPerBlock));   
  25.   
  26.     FMD_ReadSector(dwBlock*g_FlashInfo.wSectorsPerBlock, NULL, &si, 1);   
  27.   
  28.     // Stepldr & Eboot image in nand flash   
  29.     // block mark as BLOCK_STATUS_RESERVED & BLOCK_STATUS_READONLY & BLOCK_STATUS_BAD   
  30.     if ((si.bBadBlock == 0x0) && (si.bOEMReserved !=3 ))   
  31.     {   
  32.       ++dwBlock;   
  33.       ++dwNumBlocks;                // Compensate for fact that we didn't write any blocks.   
  34.       continue;   
  35.     }   
  36.   
  37.     if (!ReadBlock(dwBlock, NULL, g_pSectorInfoBuf))   
  38.     {   
  39.       OALMSG(OAL_ERROR, (TEXT("WriteData: failed to read block (0x%x).\r\n"), dwBlock));   
  40.       return(FALSE);   
  41.     }   
  42.   
  43.     if (!FMD_EraseBlock(dwBlock))   
  44.     {   
  45.       OALMSG(OAL_ERROR, (TEXT("WriteData: failed to erase block (0x%x).\r\n"), dwBlock));   
  46.       return FALSE;   
  47.     }   
  48.   
  49.     if (!WriteBlock(dwBlock, pbBuffer, g_pSectorInfoBuf))   
  50.     { <pre name="code" class="cpp">if (!OEMReadData (sizeof (DWORD), (LPBYTE) &dwDWNAddress) ||  
  51.                         !OEMReadData (sizeof (DWORD), (LPBYTE) &dwDWNAddress) ||  
  52.                         !OEMReadData (sizeof (DWORD), (LPBYTE) &dwDWNlength))  
  53.                     {  
  54.                         KITLOutputDebugString ("\r\nUnable to read add + size message.\r\n");  
  55.                         return (FALSE);  
  56.                     }  
  57.                     else  
  58.                     {  
  59.                         KITLOutputDebugString ("\rAddr: 0x%x ; Size: 0x%x\n",dwDWNAddress,dwDWNlength);  
  60.                     }</pre><br>  
  61. OALMSG(OAL_ERROR, (TEXT("WriteData: failed to write block (0x%x).\r\n"), dwBlock)); return(FALSE); } ++dwBlock; pbBuffer += g_FlashInfo.dwBytesPerBlock; OALMSG(0, (TEXT("dwBytesPerBlock : %d\r\n"), g_FlashInfo.dwBytesPerBlock)); } OALMSG(1, (TEXT(" DownLoading  
  62.  Logo success!\r\n"))); return TRUE; }<p></p>  
  63. <pre></pre>  
  64. <br>  
  65. <br>  
  66. 对于图片提取可以直接写入到NandFlash格式的数据使用Image2LCD这个软件选择16位彩色,RGB565生成BIN文件。下载地址<a href="http://download.csdn.net/detail/qq236106303/4371268">http://download.csdn.net/detail/qq236106303/4371268</a>  
  67. <p></p>  
  68. <p><br>  
  69. </p>  
  70. <p>开始使用USB下载图片时候,遇到花屏的问题,使用H-JTAG下载上面生成的bin格式的图片。能够正常显示。因此确定是USB下载有问题。而显示函数和图片格式已经正确。但是HJTAG并口下载速度太慢,不适合生产使用。所以找了下原因。 发现时因为DNW通过USB下载的时候会自动在我们选择的文件之前加上头信息。因此在程序mainMenu中,我使用了</p><pre name="code" class="cpp">if (!OEMReadData (sizeof (DWORD), (LPBYTE) &dwDWNAddress) ||  
  71.                         !OEMReadData (sizeof (DWORD), (LPBYTE) &dwDWNAddress) ||  
  72.                         !OEMReadData (sizeof (DWORD), (LPBYTE) &dwDWNlength))  
  73.                     {  
  74.                         KITLOutputDebugString ("\r\nUnable to read add + size message.\r\n");  
  75.                         return (FALSE);  
  76.                     }  
  77.                     else  
  78.                     {  
  79.                         KITLOutputDebugString ("\rAddr: 0x%x ; Size: 0x%x\n",dwDWNAddress,dwDWNlength);  
  80.                     }</pre>先读取DNW强加的非图片的数据,之后没有出现花屏的现象。但是对于DNW的源码没有研究,所以也不是特别确定,幸亏问题可以解决。 调试的时候可以采用打印SDRAM中的数据的方法进行调试,因为程序中指定的下载到SDRAM的地址是FILE_CACHE_START这个地址。<p></p>  
  81. <p><br>  
  82. </p>  
  83. <p>下载完成logo以后,选择菜单马上进行下载NK.BIN文件,发现出现错误,说BIN文件的格式不支持。以为下载内核BIN文件,会根据开始7个字节的数据判断文件时Eboot还是nk。打印出来的信息看到开始的几个字节和NK,BIN里面的数据出现了偏移。因此也怀疑是DNW搞的鬼,最后在blcommon.c的DownloadImage函数中修改</p>  
  84. <p></p><pre name="code" class="cpp">if (!OEMReadData (2*sizeof (UCHAR), (LPBYTE) &dwDWNAddress) ||   //根据打印调试出来看,出现的2个字节偏移是因为在这里读取了DWORD,所以改成2个char  
  85.         !OEMReadData (sizeof (DWORD), (LPBYTE) &dwDWNAddress) ||  
  86.         !OEMReadData (sizeof (DWORD), (LPBYTE) &dwDWNlength))  
  87.     {  
  88.             KITLOutputDebugString ("\r\nUnable to read add + size message.\r\n");  
  89.             return (FALSE);  
  90.      }  
  91.     else  
  92.     {  
  93.             KITLOutputDebugString ("\rAddr: 0x%x ; Size: 0x%x\n",dwDWNAddress,dwDWNlength);  
  94.     }  
  95. </pre><p></p>  
  96. <p><br>  
  97. </p>  
  98. <span style="white-space:pre"></span>通过上面的修改可以顺利的使用USB先下载LOGO.BIN然后再下载NK.BIN。<br>  
  99. <br>  
  100. <p><br>  
  101. </p>  
  102.       
  103.         <div style="padding-top:20px">           
  104.             <p style="font-size:12px;">版权声明:本文为博主原创文章,未经博主允许不得转载。</p>  
举报

相关文章推荐

WinCE6.0 修改开机Logo方法集锦(三)

一样的格式,这样不需要可以共用Eboot.bin实验平台:WinCE6.0+Android6410 +4.3实现该方法的首要任务就是生成特定格式的Logo.bin文件的格式这里就不再细说了,可以参...

WinCE6.0 修改开机Logo方法

开机Logo的修改方法主要有两种: 方法一:定义一个头文件,里面包含一个很大的数组,都是图片的相关数据,一起打包到Eboot的bin文件中。这种方法优点是简单直接,缺点是 图片不能太大,否则会...

我是如何成为一名python大咖的?

人生苦短,都说必须python,那么我分享下我是如何从小白成为Python资深开发者的吧。2014年我大学刚毕业..

WinCE开机Logo的实现(USB下载图片到nandflash)

WinCE开机启动Logo使用Eboot读取NandFlash中的图片数据,然后显示的方式。对于开机logo的方式网友http://jazka.blog.51cto.com/809003/664131...

WinCE6.0 修改开机Logo方法集锦(一)

从今年4月份开始接触WinCE,本来计划坚持写相关的博客,记录自己WinCE的学习历程,但整个8月份就断层了,这里面有客观原因也有主观原因,工作上的事不顺心啊。项目上需要写WinCE上的应用软件开发,...

基于Nandflash的Bootloader的设计与实现(WinCE&2410)

摘要:Bootloader是系统上电或复位后首先运行一段代码,是连接操作系统和硬件桥梁,负责初始化硬件和引导操作系统等。目前已有很多通用Bootloader,但是如何根据特定嵌入式平台,移植自己引导程...

《tiny6410裸机程序》第六章:myled通过usb下载至nandflash不能运行

====================================================================================================...

【Rayeager PX2】andoid开机logo分析及PX上的实现

PX2烧的系统也是android的时候,那么修改logo的方式也就大同小异啦,楼主也比较闲,就来试试修改logo。 大家都知道android启动界面分三步, 一步是内核的启动logo, 然后是a...

基于WINCE6.0+S3C6410通过USB下载stepldr

********************************LoongEmbedded******************************** 作者:LoongEmbedded(kand...

用JLink(V8) + AXD烧写FL2440的BootLoader并利用USB线下载WinCE和Linux

//----------------------------------------------------------------------------------------// 题    目:...
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

(最多只允许输入30个字)