/*
 *  linux/kernel/mktime.c
 *
 *  Copyright (C) 1991, 1992  Linus Torvalds
 */

#include <linux/mktime.h>

/*
 * This isn't the library routine, it is only used in the kernel.
 * as such, we don't care about years<1970 etc, but assume everything
 * is ok. Similarly, TZ etc is happily ignored. We just do everything
 * as easily as possible. Let's find something public for the library
 * routines (although I think minix times is public).
 */
/*
 * PS. I hate whoever though up the year 1970 - couldn't they have gotten
 * a leap-year instead? I also hate Gregorius, pope or no. I'm grumpy.
 */
#define MINUTE 60                     //1分钟60秒
#define HOUR (60*MINUTE)              //一小时 60 * MINUTE秒
#define DAY (24*HOUR)                 //一天有多少秒
#define YEAR (365*DAY)                //一年有多少秒

/* interestingly, we assume leap-years */
//假设为闰年,计算每个月过去秒数
static int month[12] = {
    0,                                     //进入新的一年过去的秒数
    DAY*(31),                              //一月过去之后占用的秒数
    DAY*(31+29),                           //二月过去之后占用的秒数
    DAY*(31+29+31),                        //三月过去之后占用的秒数
    DAY*(31+29+31+30),                     //四月过去之后占用的秒数
    DAY*(31+29+31+30+31),                  //五月过去之后占用的秒数
    DAY*(31+29+31+30+31+30),               //六月过去之后占用的秒数
    DAY*(31+29+31+30+31+30+31),            //七月过去之后占用的秒数
    DAY*(31+29+31+30+31+30+31+31),         //八月过去之后占用的秒数
    DAY*(31+29+31+30+31+30+31+31+30),      //九月过去之后占用的秒数
    DAY*(31+29+31+30+31+30+31+31+30+31),   //十月过去之后占用的秒数
    DAY*(31+29+31+30+31+30+31+31+30+31+30) //十一月过去之后占用的秒数(12月过去要计算整年)
};
//初始化内核时间
long kernel_mktime(struct mktime * time)
{
    long res;
    int year;

year = time->year - 70;   //从1970年一月0点0分0秒
/* magic offsets (y+1) needed to get leapyears right.*/
    res = YEAR*year + DAY*((year+1)/4); //从计时时间开始到今年共有多少秒
    res += month[time->mon];            //加上已经过去的月份的秒数(假设为闰年)
/* and (y+2) here. If it wasn't a leap-year, we have to adjust */
    if (time->mon>1 && ((year+2)%4))    //判断是否为闰年,并且是否过了二月,进行时间调整
        res -= DAY;
    res += DAY*(time->day-1);           //加上这个月过去的天数所占有的秒数
    res += HOUR*time->hour;             //加上过去的小时数占有的秒数
    res += MINUTE*time->min;            //加上过去的分钟数占有的秒数
    res += time->sec;                   //加上过去的秒数
    return res;                         //结果为计时开始到现在为止过去的秒数
}

kernel/mktime的更多相关文章

  1. Linux0.11内核剖析--内核代码(kernel)--sched.c

    1.概述 linux/kernel/目录下共包括 10 个 C 语言文件和 2 个汇编语言文件以及一个 kernel 下编译文件的管理配置文件 Makefile.其中三个子目录中代码注释的将放在后面的 ...

  2. 《linux 内核全然剖析》 mktime.c

    tm结构体的定义在time.h里面 struct tm { int tm_sec; int tm_min; int tm_hour; int tm_mday; int tm_mon; int tm_y ...

  3. kernel/Makefile

    ## Makefile for the linux kernel.## Note! Dependencies are done automagically by 'make dep', which a ...

  4. Linux 内核概述 - Linux Kernel

    Linux 内核学习笔记整理. Unix unix 已有40历史,但计算机科学家仍认为其是现存操作系统中最大和最优秀的系统,它已成为一种传奇的存在,历经时间的考验却依然声名不坠. 1973 年,在用 ...

  5. 04.ubuntu下kvm 命令行安装64位ubuntu报"Couldn't find hvm kernel for Ubuntu tree."的问题

    1.安装ubuntu时使用的virt-install的配置: virt-install \ --name test4 \ --ram 1024 \ --disk path=/data/01_ubunt ...

  6. 在 kernel 下打 log。 怪異現象與解決方式。

    code battery_log(BAT_LOG_CRTI, "y t: %d \n", (int)my_timer_timeout); battery_log(BAT_LOG_C ...

  7. 机器学习——支持向量机(SVM)之核函数(kernel)

    对于线性不可分的数据集,可以利用核函数(kernel)将数据转换成易于分类器理解的形式. 如下图,如果在x轴和y轴构成的坐标系中插入直线进行分类的话, 不能得到理想的结果,或许我们可以对圆中的数据进行 ...

  8. User space 与 Kernel space

    学习 Linux 时,经常可以看到两个词:User space(用户空间)和 Kernel space(内核空间). 简单说,Kernel space 是 Linux 内核的运行空间,User spa ...

  9. kernel 4.4.12 外部模块Makefile 脚本编写

    kernel 4.4.12 最简单module的编译 上一篇博客上面有一个最简单的模块源代码,今天就上一个Makefile,运行make 就可以编译一个外部的模块. vim Makefile 这个是我 ...

随机推荐

  1. C#如何获取项目中的其他文件夹的路径

    //一般用string p=AppDomain.CurrentDomain.BaseDirectory+"\\其他"; //其它的还有 string str1 =Process.G ...

  2. XML特殊字符处理

    XML共有5个特殊字符,分别为:&<>"' 如果XML文件中需要包含如上5个特殊字符,有两种方式: 1.将包含特殊字符的字符串放在<![CDATA[]]>中 ...

  3. Java特性-Collection和Map

    创建博客的目的主要帮助自己记忆和复习日常学到和用到的知识:或有纰漏请大家斧正,非常感谢! 之前面试,被问过一个问题:List和Set的区别. 主要区别很明显了,两者都是数组形式存在的,继承了Colle ...

  4. Performance Considerations for Entity Framework 4, 5, and 6

    Performance Considerations for Entity Framework 4, 5, and 6 https://msdn.microsoft.com/en-sg/data/hh ...

  5. Python的平凡之路(15)

    一.CSS补充: 1. 上节课讲述 a.css重用               <style>            如果整个页面的宽度 > 900px时:            { ...

  6. oracle问题

    (1) 连通性: 注册中心负责服务地址的注册与查找,相当于目录服务,服务提供者和消费者只在启动时与注册中心交互,注册中心不转发请求,压力较小 监控中心负责统计各服务调用次数,调用时间等,统计先在内存汇 ...

  7. Mybatis 源码分析--Configuration.xml配置文件加载到内存

    (补充知识点: 1 byte(字节)=8 bit(位) 通常一个标准英文字母占一个字节位置,一个标准汉字占两个字节位置:字符的例子有:字母.数字系统或标点符号) 1.创建SqlSessionFacto ...

  8. Ruby-1

    Ruby API 文档 http://www.ruby-doc.org/core-2.0.0/ Programming Ruby http://ishare.iask.sina.com.cn/f/22 ...

  9. java开发模式学习

    1.瀑布模式 这种模式适合小项目,一层层进行编码,没有规模的设计, 2.原型模式 先做模板给客户在做实体 3.面向对象模式 用面向对象的思想进行开发 4.螺旋模式 从内到外一层层开,

  10. xp下安装jdk8

    下载jdk8安装包,地址:http://www.oracle.com/technetwork/java/javase/downloads/jdk8-downloads-2133151.html下载7- ...