请教一下,最近在用usb_msc的例程调试向U盘中写入文件的功能,设计目标是把一个结构体写入文件,方法如下:
typedef struct { uint32 a; uint64 b; }data: void fun(void) { data senddata; senddata.a = 0x12345678; senddata.b = 0x1234567812345678; f_write(&g_sFileObject,&senddata,sizeof(senddata),&bytes_written); f_sync(&g_sFileObject); }
在调试过程中发现,f_write调用后,在fatfs调用内部把senddata内部的数据拷贝到了另外一个缓冲区buff中,然后会多次调用例程中fat_usbmsc.c文件中的disk_write方法。在disk_write方法中会调用usblib中的USBHMSCBlockWrite(tUSBHMSCInstance *psMSCInstance, uint32_t ui32LBA, uint8_t *pui8Data, uint32_t ui32NumBlocks)方法,此方法调用时pui8Data位置的参数就是上面说的地址为buff的缓冲区,从memory window查看这个地址,可以看到在disk_write方法的多次调用中,在倒数第二次调用时,这个地址内包含的数据是senddata结构体中的数据,也就是说在调用USBHMSCBlockWrite时确实把所有数据都传给usblib进行发送了。
但是最后的结果是到了U盘的文件中 只能看到78 34 78 34 78 34这六个八位数据。
我的分析如下:DSP的字节是16位,所以我的结构体sizeof的结果是6,也就是一共需要发6个16位数据,但是在usblib内部的某个地方被改成了6个8位数据,所以6个16位数据的高8位全部丢掉了。
请问我的判断是否正确?如果判断正确的话,这部分是在哪里处理的呢?