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

时间:2021-09-17 15:31:58

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. DWORD dwDWNAddress;
  5. DWORD dwDWNlength;
  6. DWORD i;
  7. BYTE Temp[10];
  8. DWORD dwStartAddr = 0;
  9. LPBYTE lpDes = NULL;
  10. lpDes = (LPBYTE)(FILE_CACHE_START);
  11. OALMSG(TRUE, (TEXT("Please send the Logo through USB.\r\n")));
  12. g_bUSBDownload = TRUE;
  13. <span style="white-space:pre">  </span>if (!OEMReadData (sizeof (DWORD), (LPBYTE) &dwDWNAddress) ||
  14. !OEMReadData (sizeof (DWORD), (LPBYTE) &dwDWNAddress) ||
  15. !OEMReadData (sizeof (DWORD), (LPBYTE) &dwDWNlength))
  16. {
  17. <span style="white-space:pre">  </span>KITLOutputDebugString ("\r\nUnable to read add + size message.\r\n");
  18. return (FALSE);
  19. }
  20. else
  21. {
  22. <span style="white-space:pre">  </span>KITLOutputDebugString ("\rAddr: 0x%x ; Size: 0x%x\n",dwDWNAddress,dwDWNlength);
  23. }
  24. if (!OEMReadData(640*480*2, lpDes))
  25. {
  26. <span style="white-space:pre">  </span>OALMSG(TRUE, (TEXT("Error when sending the Logo through USB.\r\n")));
  27. SpinForever();
  28. }
  29. for( i=0; i<20; i++)
  30. <span style="white-space:pre">    </span>OALMSG(0, (TEXT("->0x%x\r\n"),*(lpDes+(640*480*2-10)+i)));
  31. dwStartAddr = (DWORD)lpDes;
  32. if (!WriteLogoToBootMedia(dwStartAddr, (DWORD)(640*480*2), dwStartAddr))
  33. {
  34. <span style="white-space:pre">  </span>OALMSG(TRUE, (TEXT("Error when WriteLogoToBootMedia.\r\n")));
  35. SpinForever();
  36. }
  37. break;
  38. }

在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. k =     start_addr >> 9;
  7. for (i=0;i<2048;i++)
  8. {
  9. j = i + k;
  10. FMD_ReadSector(j, (PUCHAR)(IMAGE_FRAMEBUFFER_UA_BASE_eboot+(512*i)), &si, 1);
  11. }
  12. }

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