5

我试图将时间结构转换为 FAT 时间戳。我的代码如下所示:

unsigned long Fat(tm_struct pTime)
{
    unsigned long FatTime = 0;

    FatTime |= (pTime.seconds / 2) >> 1;
    FatTime |= (pTime.minutes) << 5;
    FatTime |= (pTime.hours) << 11;
    FatTime |= (pTime.days) << 16;
    FatTime |= (pTime.months) << 21;
    FatTime |= (pTime.years + 20) << 25;

    return FatTime;
}

有人有正确的代码吗?

4

3 回答 3

11
The DOS date/time format is a bitmask:

               24                16                 8                 0
+-+-+-+-+-+-+-+-+ +-+-+-+-+-+-+-+-+ +-+-+-+-+-+-+-+-+ +-+-+-+-+-+-+-+-+
|Y|Y|Y|Y|Y|Y|Y|M| |M|M|M|D|D|D|D|D| |h|h|h|h|h|m|m|m| |m|m|m|s|s|s|s|s|
+-+-+-+-+-+-+-+-+ +-+-+-+-+-+-+-+-+ +-+-+-+-+-+-+-+-+ +-+-+-+-+-+-+-+-+
 \___________/\________/\_________/ \________/\____________/\_________/
    year        month       day      hour       minute        second

The year is stored as an offset from 1980. 
Seconds are stored in two-second increments. 
(So if the "second" value is 15, it actually represents 30 seconds.)

我不知道您正在使用的 tm_struct 但如果它是http://www.cplusplus.com/reference/ctime/tm/那么

unsigned long FatTime = ((pTime.tm_year - 80) << 25) | 
                        ((pTime.tm_mon + 1) << 21) |
                        (pTime.tm_mday << 16) |
                        (pTime.tm_hour << 11) |
                        (pTime.tm_min << 5) |
                        (pTime.tm_sec >> 1);

编辑:如评论中所述,我在月份添加了 +1

于 2013-04-02T11:57:56.133 回答
4

Lefteris E 给出了几乎正确的答案,但这里有一个小错误

您应该将 1 添加到 tm_mon,因为 tm 结构将月份保持为从 0 到 11 的数字(struct tm),但 DOS 日期/时间从 1 到 12 (FileTimeToDosDateTime)。所以正确的是

unsigned long FatTime = ((pTime.tm_year - 80) << 25) | 
    ((pTime.tm_mon+1) << 21) |
    (pTime.tm_mday << 16) |
    (pTime.tm_hour << 11) |
    (pTime.tm_min << 5) |
    (pTime.tm_sec >> 1);
于 2017-08-08T15:52:45.060 回答
1

您也可以使用位域和库time.h。在我的项目中,我将 UNIX 时间戳转换为 FatFs 时间。

        #include <time.h>

        #pragma pack (push,1)
        typedef struct{
            unsigned Sec :5;
            unsigned Min :6;
            unsigned Hour :5;
            unsigned Day :5;
            unsigned Month :4;
            unsigned Year :7;
        }FatDate_t;
        #pragma pack (pop)

        DWORD get_fattime(void){ 
            time_t ts=GetDateTimeNow();
            struct tm * tmInfo = gmtime( &ts );
            uint32_t Result=0;
            FatDate_t *fatDate;
            fatDate=(FatDate_t *)&Result;
            fatDate->Year=tmInfo->tm_year-80;
            fatDate->Month=tmInfo->tm_mon+1;
            fatDate->Day=tmInfo->tm_mday;

            fatDate->Hour=tmInfo->tm_hour;
            fatDate->Min=tmInfo->tm_min;
            fatDate->Sec=tmInfo->tm_sec>>1;

            return Result;
        }
于 2019-09-09T15:15:00.593 回答