OpenHarmony喂狗源码解读之用户态源码 原创 精华
民之码农
 发布于 2022-1-20 08:27
 浏览
 5收藏
春节不停更,此文正在参加「星光计划-春节更帖活动」https://harmonyos.51cto.com/posts/9923
@[toc](OpenHarmony3.1Beta喂狗用户态源码解读
一、用户代码分析
1.程序等待ko加载创建字符设备
WaitAtStartup("/dev/watchdog");
#define WAIT_MAX_COUNT 10
static void WaitAtStartup(const char *source)
{
    unsigned int count = 0;
    struct stat sourceInfo;
    unsigned int waitTime = 500000;
    do {
        usleep(waitTime);
        count++;
    } while ((stat(source, &sourceInfo) < 0) && (errno == ENOENT) && (count < WAIT_MAX_COUNT));
    if (count == WAIT_MAX_COUNT) {
        INIT_LOGE("wait for file:%s failed after %f.", source, WAIT_MAX_COUNT>>1);
    }
    return;
}
程序起来等待喂狗KO加载创建/dev/watchdog 5s的时间
2.喂狗程序
int interval = 0;
    if (argc >= 2) { // Argument nums greater than or equal to 2.
        interval = atoi(argv[1]);
    }
    interval = (interval > 0) ? interval : DEFAULT_INTERVAL;
    int gap = 0;
    if (argc >= 3) { // Argument nums greater than or equal to 3.
        gap = atoi(argv[2]); // 2 second parameter.
    }
    gap = (gap > 0) ? gap : DEFAULT_GAP;
    INIT_LOGI("watchdoge started (interval %d, margin %d), fd = %d\n", interval, gap, fd);
    // 两个入参之和为用户态喂狗超时时间
    int timeoutSet = interval + gap;
    int timeoutGet = 0;
    int ret = ioctl(fd, WDIOC_SETTIMEOUT, &timeoutSet);
    if (ret) {
        INIT_LOGE("Failed to set timeout to %d\n", timeoutSet);
    }
    ret = ioctl(fd, WDIOC_GETTIMEOUT, &timeoutGet);
    if (ret) {
        INIT_LOGE("Failed to get timeout\n");
    } else {
        // 用户态设置喂狗超时时间为大于gap 用户态喂狗间隔时间为
        // 获取内核的超时间 - gap,如果小于gap 用户态喂狗超时时间为1s
        interval = (timeoutGet > gap) ? (timeoutGet - gap) : 1;
    }
    while (1) {
        ioctl(fd, WDIOC_KEEPALIVE);
        sleep(interval);
    }
    close(fd);
    fd = -1;
    return -1;
}
二、喂狗流程
加载喂狗KO ——> 创建/dev/watchdog
 ——> 注册内核函数接口open,ioctl,release
 ——> 创建内核喂狗线程hidog,并以30.01s喂狗
 ——> 用户态等待/dev/watchdog创建
 ——> 设置和获取超时时间,并计算用户态喂狗时间间隔
 ——> 以计算的喂狗时间间隔喂狗
如果用户态设置的喂狗时间超过30s,那么用户态喂狗程序退出不会影响内核线程喂狗,系统不会重启。
©著作权归作者所有,如需转载,请注明出处,否则将追究法律责任
    已于2022-1-21 08:46:23修改
 
        赞
        6
 
        收藏 5
      
 回复
  相关推荐
 




















前排追更
学习打卡
配合以下阅读,效果更佳
1、OpenHarmony喂狗源码解读之启动喂狗服务
https://harmonyos.51cto.com/posts/9945
2、OpenHarmony喂狗源码解读之内核态源码
https://harmonyos.51cto.com/posts/9966
3、OpenHarmony喂狗源码解读之用户态源码
https://harmonyos.51cto.com/posts/9967
4、OpenHarmony喂狗源码解读之Linux内核原生喂狗配置
https://harmonyos.51cto.com/posts/9969