| 
									
										
										
										
											2008-10-03 02:38:18 +04:00
										 |  |  | #include <linux/init.h>
 | 
					
						
							|  |  |  | #include <linux/proc_fs.h>
 | 
					
						
							|  |  |  | #include <linux/sched.h>
 | 
					
						
							|  |  |  | #include <linux/time.h>
 | 
					
						
							|  |  |  | #include <asm/cputime.h>
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-10-27 22:38:27 +03:00
										 |  |  | static int proc_calc_metrics(char *page, char **start, off_t off, | 
					
						
							|  |  |  | 				 int count, int *eof, int len) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	if (len <= off + count) | 
					
						
							|  |  |  | 		*eof = 1; | 
					
						
							|  |  |  | 	*start = page + off; | 
					
						
							|  |  |  | 	len -= off; | 
					
						
							|  |  |  | 	if (len > count) | 
					
						
							|  |  |  | 		len = count; | 
					
						
							|  |  |  | 	if (len < 0) | 
					
						
							|  |  |  | 		len = 0; | 
					
						
							|  |  |  | 	return len; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static int uptime_read_proc(char *page, char **start, off_t off, int count, | 
					
						
							|  |  |  | 			    int *eof, void *data) | 
					
						
							| 
									
										
										
										
											2008-10-03 02:38:18 +04:00
										 |  |  | { | 
					
						
							|  |  |  | 	struct timespec uptime; | 
					
						
							|  |  |  | 	struct timespec idle; | 
					
						
							| 
									
										
										
										
											2008-10-27 22:38:27 +03:00
										 |  |  | 	int len; | 
					
						
							| 
									
										
										
										
											2008-10-03 02:38:18 +04:00
										 |  |  | 	cputime_t idletime = cputime_add(init_task.utime, init_task.stime); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	do_posix_clock_monotonic_gettime(&uptime); | 
					
						
							|  |  |  | 	monotonic_to_bootbased(&uptime); | 
					
						
							|  |  |  | 	cputime_to_timespec(idletime, &idle); | 
					
						
							| 
									
										
										
										
											2008-10-27 22:38:27 +03:00
										 |  |  | 	len = sprintf(page, "%lu.%02lu %lu.%02lu\n", | 
					
						
							| 
									
										
										
										
											2008-10-03 02:38:18 +04:00
										 |  |  | 			(unsigned long) uptime.tv_sec, | 
					
						
							|  |  |  | 			(uptime.tv_nsec / (NSEC_PER_SEC / 100)), | 
					
						
							|  |  |  | 			(unsigned long) idle.tv_sec, | 
					
						
							|  |  |  | 			(idle.tv_nsec / (NSEC_PER_SEC / 100))); | 
					
						
							| 
									
										
										
										
											2008-10-27 22:38:27 +03:00
										 |  |  | 	return proc_calc_metrics(page, start, off, count, eof, len); | 
					
						
							| 
									
										
										
										
											2008-10-03 02:38:18 +04:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static int __init proc_uptime_init(void) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2008-10-27 22:38:27 +03:00
										 |  |  | 	create_proc_read_entry("uptime", 0, NULL, uptime_read_proc, NULL); | 
					
						
							| 
									
										
										
										
											2008-10-03 02:38:18 +04:00
										 |  |  | 	return 0; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | module_init(proc_uptime_init); |