wince 启动初始化 FLASH 之后做什么?

xfzhaoyong   2009-11-9 11:11 楼主
请问,
    wince 启动的时候,初始化FLASH之后是做什么操作呢?
    我怎么知道 FLASH 初始化有没有成功呢?
谢谢

回复评论 (8)

本机驱动。...
点赞  2009-11-9 11:32
引用: 引用 1 楼 gooogleman 的回复:
本机驱动。...

本机驱动是根据什么样的一个顺序呢?
点赞  2009-11-9 11:37
看注册表
点赞  2009-11-9 12:04
根据注册表配置和系统配置的不同,也会有所不同
但不管是哪种,后面与bsp有关的操作就是流驱动的加载了,如果有hive的话,就是查hive的flag了
有点负责,看一下网上别人讲的系统启动过程可能会更清楚一点
点赞  2009-11-9 16:07
引用: 引用 4 楼 guopeixin 的回复:
根据注册表配置和系统配置的不同,也会有所不同
但不管是哪种,后面与bsp有关的操作就是流驱动的加载了,如果有hive的话,就是查hive的flag了
有点负责,看一下网上别人讲的系统启动过程可能会更清楚一点


大哥:
    这个 flag 是怎么弄的呢?
    方便加个 QQ:84651869 聊会吗?
点赞  2009-11-9 16:47
如果你是默认的或者参照其它厂家的话,可以先不用关注这个,因为这里涉及到ms的一些代码,太麻烦了
如果单纯的为了验证flash的hw初始化是否成功的话,直接在fmd_init里面读取两个sector就行了
点赞  2009-11-9 17:52
引用: 引用 6 楼 guopeixin 的回复:
如果你是默认的或者参照其它厂家的话,可以先不用关注这个,因为这里涉及到ms的一些代码,太麻烦了
如果单纯的为了验证flash的hw初始化是否成功的话,直接在fmd_init里面读取两个sector就行了

我的启动调试信息如下:
TrueFFS, DSK_INIT(): =========================
TrueFFS, DSK_INIT(): [END] pDisk = 0xc0a0e968
TrueFFS, DSK_INIT(): ========================
TrueFFS, DSK_INIT(): =========================
TrueFFS, DSK_INIT(): [END] pDisk = 0xc0a0e968
TrueFFS, DSK_INIT(): ========================
TrueFFS, DSK_Open(): DSK_Open [START]
TrueFFS, DSK_Open(): Partition was closed, trying to mount it.
TrueFFS, mountDisk(): [START] pDisk = 0xc0a0e968
TrueFFS,  GetDiskHandle volumeNo =2, deviceNo=0, partitionNo = 2 TrueFFS,  GetDiskHandle Device TrueFFS handle=32
++++dochCheckPFSymptom

Socket #0 - ChipID OK
Device Found: H3++++dochCheckPFSymptom

Socket #0 - ChipID OK
Device Found: H3++++dochCheckPFSymptom

Socket #0 - ChipID OK
Device Found: H3++++dochCheckPFSymptom

Socket #0 - ChipID OK
Device Found: H3TrueFFS, mountDisk(): absMount was done successfully.
TrueFFS,  GetDiskHandle volumeNo =2, deviceNo=0, partitionNo = 2 TrueFFS,  GetDiskHandle Device TrueFFS handle=32
++++dochCheckPFSymptom

Socket #0 - ChipID OK
Device Found: H3++++dochCheckPFSymptom

Socket #0 - ChipID OK
Device Found: H3TrueFFS, mountDisk(): [END], returning 0
TrueFFS, DSK_Open(): [END] returning pDisk=0xC0A0E968
TrueFFS, IO: dwIoControlCode=1
TrueFFS,  GetDiskHandle volumeNo =2, deviceNo=0, partitionNo = 2 TrueFFS,  GetDiskHandle Device TrueFFS handle=32
TrueFFS, IO: dwIoControlCode=464896
TrueFFS,  GetDiskHandle volumeNo =2, deviceNo=0, partitionNo = 2 TrueFFS,  GetDiskHandle Device TrueFFS handle=32
TrueFFS, IO: processing IOCTL_DISK_DEVICE_INFO
TrueFFS, getRegValue(): FieldName = Profile, length = 26
TrueFFS, IO: returned profile  is 'TRUEFFS_DOC2'
TrueFFS, IO: returned dwDeviceClass is 0x
xTrueFFS, IO: returned dwDeviceType is 0x40001000
TrueFFS, IO: returned dwDeviceFlags is 0x1
TrueFFS, IO: dwIoControlCode=465956
TrueFFS,  GetDiskHandle volumeNo =2, deviceNo=0, partitionNo = 2 TrueFFS,  GetDiskHandle Device TrueFFS handle=32
TrueFFS, IO: processing IOCTL_DISK_GET_STORAGEID
TrueFFS, IO: dwIoControlCode=465920
TrueFFS,  GetDiskHandle volumeNo =2, deviceNo=0, partitionNo = 2 TrueFFS,  GetDiskHandle Device TrueFFS handle=32
TrueFFS, IO: dwIoControlCode=482312
TrueFFS,  GetDiskHandle volumeNo =2, deviceNo=0, partitionNo = 2 TrueFFS,  GetDiskHandle Device TrueFFS handle=32
TrueFFS, IO: processing IOCTL_DISK_READ / IOCTL_DISK_WRITE operation.
TrueFFS,  GetDiskHandle volumeNo =2, deviceNo=0, partitionNo = 2 TrueFFS,  GetDiskHandle Device TrueFFS handle=32
TrueFFS, doDiskIo(): Reading 1 sectors starting at sector 0
++++dochCheckPFSymptom

Socket #0 - ChipID OK
Device Found: H3++++dochCheckPFSymptom

Socket #0 - ChipID OK
Device Found: H3

这样是不是说 FLSAH 初始化没问题啦??
如果FLASH 初始化没问题,
那么FLASH 初始化后接下来是做什么呢?
点赞  2009-11-9 21:46
请问是不是 FLASH 初始化之后就执行
KernelInit函数:
    Windows CE 6.0的内核初始化函数同其他版本的内核初始化函数基本相近,主要完成在启动第一个线程前对内核进行初始化,主要包括API函数集初始化、堆的初始化、初始化内存池、进程初始化、线程初始化和文件映射初始化等操作。
void KernelInit (void)
{
#ifdef DEBUG
    g_pNKGlobal->pfnWriteDebugString (TEXT("Windows CE KernelInit\r\n"));
#endif
    APICallInit ();// setup API set
    HeapInit ();// setup kernel heap
    InitMemoryPool ();// setup physical memory
    PROCInit ();// initialize process
    VMInit (g_pprcNK);// setup VM for kernel
    THRDInit ();// initialize threadsv
    MapfileInit ();
#ifdef DEBUG
    g_pNKGlobal->pfnWriteDebugString (TEXT("Scheduling the first thread.\r\n"));
#endif
}
???
是不是这样的步骤呢?
点赞  2009-11-9 22:05
电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 京公网安备 11010802033920号
    写回复