netdev.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
From: Frederik Deweerdt <deweerdt@free.fr>
To: Evgeniy Polyakov <johnpol@2ka.mipt.ru>
Cc: David Miller <davem@davemloft.net>,
	Ulrich Drepper <drepper@redhat.com>,
	Andrew Morton <akpm@osdl.org>, netdev <netdev@vger.kernel.org>,
	Zach Brown <zach.brown@oracle.com>,
	Christoph Hellwig <hch@infradead.org>,
	Ch@pimp.vs19.net
Subject: Re: [take37 0/10] kevent: Generic event handling mechanism (socket, pipes, files, signals, AIO, timers, posix timers...).
Date: Thu, 22 Feb 2007 15:17:40 +0000	[thread overview]
Message-ID: <20070222151740.GD4113@slug> (raw)
In-Reply-To: <11721524921823@2ka.mipt.ru>

On Thu, Feb 22, 2007 at 04:54:52PM +0300, Evgeniy Polyakov wrote:
 
> Changes from 'take36' patchset:
>  * ported to 2.6.21-rc1
Hi Evgeniy,

The changes below were needed to be able to compile take37 on 2.6.21-rc1
with:
CONFIG_KEVENT=y
CONFIG_KEVENT_USER_STAT=y
CONFIG_KEVENT_TIMER=y
CONFIG_KEVENT_POLL=y
CONFIG_KEVENT_SOCKET=y
CONFIG_KEVENT_PIPE=y
CONFIG_KEVENT_SIGNAL=y
CONFIG_KEVENT_UNOTIFY=y
CONFIG_KEVENT_AIO=y

Regards,
Frederik

diff --git a/kernel/kevent/kevent_timer.c b/kernel/kevent/kevent_timer.c
index c21a155..19f0a88 100644
--- a/kernel/kevent/kevent_timer.c
+++ b/kernel/kevent/kevent_timer.c
@@ -33,7 +33,7 @@ struct kevent_timer
 	struct kevent		*ktimer_event;
 };
 
-static int kevent_timer_func(struct hrtimer *timer)
+static enum hrtimer_restart kevent_timer_func(struct hrtimer *timer)
 {
 	struct kevent_timer *t = container_of(timer, struct kevent_timer, ktimer);
 	struct kevent *k = t->ktimer_event;
@@ -55,7 +55,7 @@ static int kevent_timer_enqueue(struct kevent *k)
 	if (!t)
 		return -ENOMEM;
 
-	hrtimer_init(&t->ktimer, CLOCK_MONOTONIC, HRTIMER_REL);
+	hrtimer_init(&t->ktimer, CLOCK_MONOTONIC, HRTIMER_MODE_REL);
 	t->ktimer.expires = ktime_set(k->event.id.raw[0], k->event.id.raw[1]);
 	t->ktimer.function = kevent_timer_func;
 	t->ktimer_event = k;
@@ -69,7 +69,7 @@ static int kevent_timer_enqueue(struct kevent *k)
 	if (err)
 		goto err_out_st_fini;
 
-	hrtimer_start(&t->ktimer, t->ktimer.expires, HRTIMER_REL);
+	hrtimer_start(&t->ktimer, t->ktimer.expires, HRTIMER_MODE_REL);
 
 	return 0;
 
diff --git a/kernel/kevent/kevent_user.c b/kernel/kevent/kevent_user.c
index f25d696..883b82b 100644
--- a/kernel/kevent/kevent_user.c
+++ b/kernel/kevent/kevent_user.c
@@ -152,7 +152,7 @@ static struct kevent_user *kevent_user_alloc(struct kevent_ring __user *ring, un
 	u->pring = ring;
 	u->ring_size = num;
 
-	hrtimer_init(&u->timer, CLOCK_REALTIME, HRTIMER_ABS);
+	hrtimer_init(&u->timer, CLOCK_REALTIME, HRTIMER_MODE_ABS);
 
 	kevent_storage_init(u, &u->st);
 
@@ -881,7 +881,7 @@ out_remove:
 }
 
 /* Used to wakeup waiting syscalls in case high-resolution timer is used. */
-static int kevent_user_wake(struct hrtimer *timer)
+static enum hrtimer_restart kevent_user_wake(struct hrtimer *timer)
 {
 	struct kevent_user *u = container_of(timer, struct kevent_user, timer);
 
@@ -910,10 +910,10 @@ static int kevent_user_wait(struct file *file, struct kevent_user *u,
 
 		if (flags & KEVENT_FLAGS_ABSTIME) {
 			hrtimer_cancel(&u->timer);
-			hrtimer_init(&u->timer, CLOCK_REALTIME, HRTIMER_ABS);
+			hrtimer_init(&u->timer, CLOCK_REALTIME, HRTIMER_MODE_ABS);
 			u->timer.expires = ktime_set(timeout.tv_sec, timeout.tv_nsec);
 			u->timer.function = &kevent_user_wake;
-			hrtimer_start(&u->timer, u->timer.expires, HRTIMER_ABS);
+			hrtimer_start(&u->timer, u->timer.expires, HRTIMER_MODE_ABS);
 			if (unlikely(kevent_debug_abstime == 0)) {
 				printk(KERN_INFO "kevent: author was wrong, "
 						"someone uses absolute time in %s, "
@@ -1214,10 +1214,10 @@ asmlinkage long sys_kevent_wait(int ctl_fd, unsigned int num, unsigned int old_u
 
 		if (flags & KEVENT_FLAGS_ABSTIME) {
 			hrtimer_cancel(&u->timer);
-			hrtimer_init(&u->timer, CLOCK_REALTIME, HRTIMER_ABS);
+			hrtimer_init(&u->timer, CLOCK_REALTIME, HRTIMER_MODE_ABS);
 			u->timer.expires = ktime_set(timeout.tv_sec, timeout.tv_nsec);
 			u->timer.function = &kevent_user_wake;
-			hrtimer_start(&u->timer, u->timer.expires, HRTIMER_ABS);
+			hrtimer_start(&u->timer, u->timer.expires, HRTIMER_MODE_ABS);
 			if (unlikely(kevent_debug_abstime == 0)) {
 				printk(KERN_INFO "kevent: author was wrong, "
 						"someone uses absolute time in %s, "

  parent reply	other threads:[~2007-02-22 15:19 UTC|newest]

Thread overview: 18+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
     [not found] <asasdasdzxczc036@2ka.mipt.ru>
2007-02-22 13:54 ` [take37 0/10] kevent: Generic event handling mechanism (socket, pipes, files, signals, AIO, timers, posix timers...) Evgeniy Polyakov
2007-02-22 13:54   ` [take37 1/10] kevent: Description Evgeniy Polyakov
2007-02-22 13:55     ` [take37 2/10] kevent: Core files Evgeniy Polyakov
2007-02-22 13:55       ` [take37 3/10] kevent: poll/select() notifications Evgeniy Polyakov
2007-02-22 13:55         ` [take37 4/10] kevent: Socket notifications Evgeniy Polyakov
2007-02-22 13:55           ` [take37 5/10] kevent: Timer notifications Evgeniy Polyakov
2007-02-22 13:55             ` [take37 6/10] kevent: Pipe notifications Evgeniy Polyakov
2007-02-22 13:55               ` [take37 7/10] kevent: Signal notifications Evgeniy Polyakov
2007-02-22 13:55                 ` [take37 8/10] kevent: Kevent posix timer notifications Evgeniy Polyakov
2007-02-22 13:55                   ` [take37 9/10] kevent: Private userspace notifications Evgeniy Polyakov
2007-02-22 13:55                     ` [take37 10/10] kevent: Kevent based generic AIO Evgeniy Polyakov
2007-02-22 15:17   ` Frederik Deweerdt [this message]
2007-02-22 15:27     ` [take37 0/10] kevent: Generic event handling mechanism (socket, pipes, files, signals, AIO, timers, posix timers...) Evgeniy Polyakov
2007-11-20 15:24 ` [take8 0/4] dst: Distributed storage Evgeniy Polyakov
2007-11-20 15:24   ` [take8 1/4] dst: Distributed storage documentation Evgeniy Polyakov
2007-11-20 15:24     ` [take8 2/4] dst: Core distributed storage files Evgeniy Polyakov
2007-11-20 15:24       ` [take8 3/4] dst: Network state machine Evgeniy Polyakov
2007-11-20 15:24         ` [take8 4/4] dst: Algorithms used in distributed storage Evgeniy Polyakov

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=20070222151740.GD4113@slug \
    --to=deweerdt@free.fr \
    --cc=Ch@pimp.vs19.net \
    --cc=akpm@osdl.org \
    --cc=davem@davemloft.net \
    --cc=drepper@redhat.com \
    --cc=hch@infradead.org \
    --cc=johnpol@2ka.mipt.ru \
    --cc=netdev@vger.kernel.org \
    --cc=zach.brown@oracle.com \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).