aboutsummaryrefslogtreecommitdiffstats
path: root/arch/um
diff options
context:
space:
mode:
Diffstat (limited to 'arch/um')
-rw-r--r--arch/um/include/common-offsets.h4
-rw-r--r--arch/um/include/os.h2
-rw-r--r--arch/um/kernel/time.c9
-rw-r--r--arch/um/os-Linux/skas/process.c12
-rw-r--r--arch/um/os-Linux/time.c12
5 files changed, 22 insertions, 17 deletions
diff --git a/arch/um/include/common-offsets.h b/arch/um/include/common-offsets.h
index 54694693f400..0edab695ed4e 100644
--- a/arch/um/include/common-offsets.h
+++ b/arch/um/include/common-offsets.h
@@ -34,3 +34,7 @@ DEFINE(crypto_tfm_ctx_offset, offsetof(struct crypto_tfm, __crt_ctx));
34DEFINE(UM_THREAD_SIZE, THREAD_SIZE); 34DEFINE(UM_THREAD_SIZE, THREAD_SIZE);
35 35
36DEFINE(UM_HZ, HZ); 36DEFINE(UM_HZ, HZ);
37
38DEFINE(UM_USEC_PER_SEC, USEC_PER_SEC);
39DEFINE(UM_NSEC_PER_SEC, NSEC_PER_SEC);
40DEFINE(UM_NSEC_PER_USEC, NSEC_PER_USEC);
diff --git a/arch/um/include/os.h b/arch/um/include/os.h
index a1b0804ee57b..fbf0a87c6eaa 100644
--- a/arch/um/include/os.h
+++ b/arch/um/include/os.h
@@ -249,8 +249,6 @@ extern int setjmp_wrapper(void (*proc)(void *, void *), ...);
249extern void os_dump_core(void); 249extern void os_dump_core(void);
250 250
251/* time.c */ 251/* time.c */
252#define BILLION (1000 * 1000 * 1000)
253
254extern void idle_sleep(unsigned long long nsecs); 252extern void idle_sleep(unsigned long long nsecs);
255extern int set_interval(void); 253extern int set_interval(void);
256extern int timer_one_shot(int ticks); 254extern int timer_one_shot(int ticks);
diff --git a/arch/um/kernel/time.c b/arch/um/kernel/time.c
index 2acdc7efb2ac..1ac746a9eae1 100644
--- a/arch/um/kernel/time.c
+++ b/arch/um/kernel/time.c
@@ -17,7 +17,7 @@
17 */ 17 */
18unsigned long long sched_clock(void) 18unsigned long long sched_clock(void)
19{ 19{
20 return (unsigned long long)jiffies_64 * (1000000000 / HZ); 20 return (unsigned long long)jiffies_64 * (NSEC_PER_SEC / HZ);
21} 21}
22 22
23void timer_handler(int sig, struct uml_pt_regs *regs) 23void timer_handler(int sig, struct uml_pt_regs *regs)
@@ -118,8 +118,9 @@ void __init time_init(void)
118 timer_init(); 118 timer_init();
119 119
120 nsecs = os_nsecs(); 120 nsecs = os_nsecs();
121 set_normalized_timespec(&wall_to_monotonic, -nsecs / BILLION, 121 set_normalized_timespec(&wall_to_monotonic, -nsecs / NSEC_PER_SEC,
122 -nsecs % BILLION); 122 -nsecs % NSEC_PER_SEC);
123 set_normalized_timespec(&xtime, nsecs / BILLION, nsecs % BILLION); 123 set_normalized_timespec(&xtime, nsecs / NSEC_PER_SEC,
124 nsecs % NSEC_PER_SEC);
124 late_time_init = setup_itimer; 125 late_time_init = setup_itimer;
125} 126}
diff --git a/arch/um/os-Linux/skas/process.c b/arch/um/os-Linux/skas/process.c
index 9936531a2620..8548f126d628 100644
--- a/arch/um/os-Linux/skas/process.c
+++ b/arch/um/os-Linux/skas/process.c
@@ -294,8 +294,8 @@ void userspace(struct uml_pt_regs *regs)
294 294
295 if (getitimer(ITIMER_VIRTUAL, &timer)) 295 if (getitimer(ITIMER_VIRTUAL, &timer))
296 printk("Failed to get itimer, errno = %d\n", errno); 296 printk("Failed to get itimer, errno = %d\n", errno);
297 nsecs = timer.it_value.tv_sec * BILLION + 297 nsecs = timer.it_value.tv_sec * UM_NSEC_PER_SEC +
298 timer.it_value.tv_usec * 1000; 298 timer.it_value.tv_usec * UM_NSEC_PER_USEC;
299 nsecs += os_nsecs(); 299 nsecs += os_nsecs();
300 300
301 while (1) { 301 while (1) {
@@ -347,8 +347,10 @@ void userspace(struct uml_pt_regs *regs)
347 block_signals(); 347 block_signals();
348 (*sig_info[sig])(sig, regs); 348 (*sig_info[sig])(sig, regs);
349 unblock_signals(); 349 unblock_signals();
350 nsecs = timer.it_value.tv_sec * BILLION + 350 nsecs = timer.it_value.tv_sec *
351 timer.it_value.tv_usec * 1000; 351 UM_NSEC_PER_SEC +
352 timer.it_value.tv_usec *
353 UM_NSEC_PER_USEC;
352 nsecs += os_nsecs(); 354 nsecs += os_nsecs();
353 break; 355 break;
354 case SIGIO: 356 case SIGIO:
@@ -395,7 +397,7 @@ __initcall(init_thread_regs);
395 397
396int copy_context_skas0(unsigned long new_stack, int pid) 398int copy_context_skas0(unsigned long new_stack, int pid)
397{ 399{
398 struct timeval tv = { .tv_sec = 0, .tv_usec = 1000000 / UM_HZ }; 400 struct timeval tv = { .tv_sec = 0, .tv_usec = UM_USEC_PER_SEC / UM_HZ };
399 int err; 401 int err;
400 unsigned long current_stack = current_stub_stack(); 402 unsigned long current_stack = current_stub_stack();
401 struct stub_data *data = (struct stub_data *) current_stack; 403 struct stub_data *data = (struct stub_data *) current_stack;
diff --git a/arch/um/os-Linux/time.c b/arch/um/os-Linux/time.c
index 574b134f0502..e34e1effe0f5 100644
--- a/arch/um/os-Linux/time.c
+++ b/arch/um/os-Linux/time.c
@@ -14,7 +14,7 @@
14 14
15int set_interval(void) 15int set_interval(void)
16{ 16{
17 int usec = 1000000/UM_HZ; 17 int usec = UM_USEC_PER_SEC / UM_HZ;
18 struct itimerval interval = ((struct itimerval) { { 0, usec }, 18 struct itimerval interval = ((struct itimerval) { { 0, usec },
19 { 0, usec } }); 19 { 0, usec } });
20 20
@@ -26,11 +26,11 @@ int set_interval(void)
26 26
27int timer_one_shot(int ticks) 27int timer_one_shot(int ticks)
28{ 28{
29 unsigned long usec = ticks * 1000000 / UM_HZ; 29 unsigned long usec = ticks * UM_USEC_PER_SEC / UM_HZ;
30 unsigned long sec = usec / 1000000; 30 unsigned long sec = usec / UM_USEC_PER_SEC;
31 struct itimerval interval; 31 struct itimerval interval;
32 32
33 usec %= 1000000; 33 usec %= UM_USEC_PER_SEC;
34 interval = ((struct itimerval) { { 0, 0 }, { sec, usec } }); 34 interval = ((struct itimerval) { { 0, 0 }, { sec, usec } });
35 35
36 if (setitimer(ITIMER_VIRTUAL, &interval, NULL) == -1) 36 if (setitimer(ITIMER_VIRTUAL, &interval, NULL) == -1)
@@ -78,8 +78,8 @@ extern void alarm_handler(int sig, struct sigcontext *sc);
78 78
79void idle_sleep(unsigned long long nsecs) 79void idle_sleep(unsigned long long nsecs)
80{ 80{
81 struct timespec ts = { .tv_sec = nsecs / BILLION, 81 struct timespec ts = { .tv_sec = nsecs / UM_NSEC_PER_SEC,
82 .tv_nsec = nsecs % BILLION }; 82 .tv_nsec = nsecs % UM_NSEC_PER_SEC };
83 83
84 if (nanosleep(&ts, &ts) == 0) 84 if (nanosleep(&ts, &ts) == 0)
85 alarm_handler(SIGVTALRM, NULL); 85 alarm_handler(SIGVTALRM, NULL);