uptime.c 1.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849
  1. // SPDX-License-Identifier: GPL-2.0
  2. #include <linux/fs.h>
  3. #include <linux/init.h>
  4. #include <linux/proc_fs.h>
  5. #include <linux/sched.h>
  6. #include <linux/seq_file.h>
  7. #include <linux/time.h>
  8. #include <linux/time_namespace.h>
  9. #include <linux/kernel_stat.h>
  10. #include "internal.h"
  11. static int uptime_proc_show(struct seq_file *m, void *v)
  12. {
  13. struct timespec64 uptime;
  14. struct timespec64 idle;
  15. u64 idle_nsec;
  16. u32 rem;
  17. int i;
  18. idle_nsec = 0;
  19. for_each_possible_cpu(i) {
  20. struct kernel_cpustat kcs;
  21. kcpustat_cpu_fetch(&kcs, i);
  22. idle_nsec += get_idle_time(&kcs, i);
  23. }
  24. ktime_get_boottime_ts64(&uptime);
  25. timens_add_boottime(&uptime);
  26. idle.tv_sec = div_u64_rem(idle_nsec, NSEC_PER_SEC, &rem);
  27. idle.tv_nsec = rem;
  28. seq_printf(m, "%lu.%02lu %lu.%02lu\n",
  29. (unsigned long) uptime.tv_sec,
  30. (uptime.tv_nsec / (NSEC_PER_SEC / 100)),
  31. (unsigned long) idle.tv_sec,
  32. (idle.tv_nsec / (NSEC_PER_SEC / 100)));
  33. return 0;
  34. }
  35. static int __init proc_uptime_init(void)
  36. {
  37. struct proc_dir_entry *pde;
  38. pde = proc_create_single("uptime", 0, NULL, uptime_proc_show);
  39. pde_make_permanent(pde);
  40. return 0;
  41. }
  42. fs_initcall(proc_uptime_init);