/*
 *  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. Buffer、Channel示例

      a.txt 孔雀向西飞,今朝更好看.孔雀向西飞,今朝更好看.孔雀向西飞,今朝更好看.孔雀向西飞,今朝更好看. 示例一. package com.test; import java.io.FileI ...

  2. TreeMap 的实现

    TreeMap 的实现就是红黑树数据结构,也就说是一棵自平衡的排序二叉树,这样就可以保证当需要快速检索指定节点. TreeSet 和 TreeMap 的关系 为了让大家了解 TreeMap 和 Tre ...

  3. iOS中AutoLayer自动布局流程及相关方法

    关于UIView的Layer,IOS提供了三个方法: 1.layoutSubviews 在iOS5.1和之前的版本,此方法的缺省实现不会做任何事情(实现为空),iOS5.1之后(iOS6开始)的版本, ...

  4. Allegro padstack

    在ALLEGRO中,建立PCB封装是一件挺复杂的事,而要建立FOOTPRINT,首先要有一个PAD,所以就要新建PADSTACK. 焊盘可以分两种,表贴焊盘和通孔焊盘,表贴焊盘结构相对简单,下面首先分 ...

  5. Java 图片压缩

    package com.wuyu.util; import java.awt.Graphics2D; import java.awt.Image; import java.awt.image.Buff ...

  6. Frame动画实战

    Android动画分为Tween动画和Frame动画,Tween动画主要包括图片的放大缩小.旋转.透明度变化.移动等等操作:Frame动画则简单得多了,就是把一张张的图片连续播放产生动画效果. 本节主 ...

  7. time元素和datetime、pubtime属性

    time:对一个时间进行标识 <time datetime="2012-12-24">2012-12-24</time> datetime:时间的值 pub ...

  8. NOIP 考前 暴力练习

    BZOJ 1028 暴力枚举听的那张牌,和那个多余的两张牌,其余的mod3后模拟就可以了 #include <cstdio> ; int n,m,a[Maxn],b[Maxn],cnt,A ...

  9. 主要由顶点容器构成的平面图形类(Shape)——(第一次作业Draw类定义升级)

    // https://github.com/orocos/orocos_kinematics_dynamics/blob/master/orocos_kdl/src/frames.hpp // Vec ...

  10. 360个人图书馆 轻松解除网页防复制 (转自老D)

    360个人图书馆会自动采集一些比较好的文章,我的博客文章也被采集过几篇,用过360个人图书馆的人都知道要复制别人的文章需要先收藏到自己的图书馆才可以复制,没有账号右键复制它会直接弹出一个提示登录框.不 ...