public inbox for linux-kernel@vger.kernel.org
 help / color / mirror / Atom feed
From: Rodolfo Giometti <giometti@enneenne.com>
To: David Woodhouse <dwmw2@infradead.org>
Cc: linux-kernel@vger.kernel.org, Andrew Morton <akpm@linux-foundation.org>
Subject: Re: [PATCH] LinuxPPS (with new syscalls API)
Date: Wed, 27 Jun 2007 14:58:02 +0200	[thread overview]
Message-ID: <20070627125802.GI13886@enneenne.com> (raw)
In-Reply-To: <1182939510.6409.17.camel@pmac.infradead.org>

On Wed, Jun 27, 2007 at 11:18:30AM +0100, David Woodhouse wrote:
> On Wed, 2007-06-27 at 12:14 +0200, Rodolfo Giometti wrote:
> > On Tue, Jun 26, 2007 at 06:38:40PM +0100, David Woodhouse wrote:
> > > 
> > > 64-bit kernels can run 32-bit userspace programs. But some structures
> > > come out _differently_ between 32-bit and 64-bit compilation, so the
> > > system call needs a special 'compat' handler instead of just running the
> > > normal 64-bit system call.
> > > 
> > > The 'struct timespec' is one structure which is sometimes different for
> > > 32-bit vs. 64-bit, so any system call taking a 'struct timespec' must
> > > have a separate compat_sys_xxxx() to handle that. See something like
> > > compat_sys_clock_settime() in kernel/compat.c for an example (but don't
> > > use set_fs() like it does; just see how it handles the compat_timespec).
> > 
> > Did you mean something like this?
> 
> How will 64-bit system calls work if you do it like that? You need to
> provide _both_ sys_time_pps_fetch() and compat_sys_time_pps_fetch().

Sorry, I'm new to this 32/64 bits issues...

Now is it correct?

diff --git a/drivers/pps/pps.c b/drivers/pps/pps.c
index befe292..b9df17b 100644
--- a/drivers/pps/pps.c
+++ b/drivers/pps/pps.c
@@ -26,6 +26,7 @@
 #include <linux/init.h>
 #include <linux/linkage.h>
 #include <linux/sched.h>
+#include <linux/compat.h>
 #include <linux/pps.h>
 #include <asm/uaccess.h>
 
@@ -362,6 +363,22 @@ sys_time_pps_fetch_exit:
        return ret;
 }
 
+#ifdef CONFIG_COMPAT
+asmlinkage long compat_sys_time_pps_fetch(int source, const int tsformat,
+                               struct pps_info __user *info, 
+                               const struct compat_timespec __user *timeout)
+{
+       int ret;
+       struct timespec to;
+
+       ret = get_compat_timespec(&to, timeout);
+       if (ret)
+               return -EFAULT;
+       
+       return sys_time_pps_fetch(source, tsformat, info, &to);
+}
+#endif
+
 /*
  * Module staff
  */

Since I have no way to test this code maybe is better add no function
at all and simply using a warning message if someone try compiling
this code with CONFIG_COMPAT enabled...

Ciao,

Rodolfo

-- 

GNU/Linux Solutions                  e-mail:    giometti@enneenne.com
Linux Device Driver                             giometti@gnudd.com
Embedded Systems                     		giometti@linux.it
UNIX programming                     phone:     +39 349 2432127

  reply	other threads:[~2007-06-27 12:56 UTC|newest]

Thread overview: 64+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2007-06-26 10:06 [PATCH] LinuxPPS (with new syscalls API) Rodolfo Giometti
2007-06-26 10:57 ` David Woodhouse
2007-06-26 17:06   ` Rodolfo Giometti
2007-06-26 17:38     ` David Woodhouse
2007-06-26 18:13       ` Rodolfo Giometti
2007-06-26 18:20         ` David Woodhouse
2007-06-27 10:14       ` Rodolfo Giometti
2007-06-27 10:18         ` David Woodhouse
2007-06-27 12:58           ` Rodolfo Giometti [this message]
2007-06-27 16:11             ` David Woodhouse
2007-06-27 17:45               ` Rodolfo Giometti
2007-06-27 17:49                 ` David Woodhouse
2007-06-27 22:46                   ` Rodolfo Giometti
2007-06-28  8:08                     ` David Woodhouse
2007-06-28  8:15                       ` Rodolfo Giometti
2007-06-28  8:31                         ` David Woodhouse
2007-06-28  8:40                           ` Rodolfo Giometti
2007-06-28 11:44                             ` David Woodhouse
2007-06-28 14:15                               ` Rodolfo Giometti
2007-06-28 16:14                               ` [PATCH] LinuxPPS (with new syscalls API) - new version Rodolfo Giometti
2007-06-29 11:38                                 ` David Woodhouse
2007-06-29 15:08                                   ` Rodolfo Giometti
2007-06-29 15:25                                     ` David Woodhouse
2007-06-29 15:38                                       ` Rodolfo Giometti
2007-06-29 15:41                                         ` David Woodhouse
2007-06-29 16:23                                           ` Rodolfo Giometti
2007-06-29 16:23                                             ` David Woodhouse
2007-06-29 16:36                                               ` Rodolfo Giometti
2007-06-29 16:38                                                 ` David Woodhouse
2007-06-29 15:55                                     ` David Woodhouse
2007-06-29 16:34                                       ` Rodolfo Giometti
2007-06-29 16:40                                         ` David Woodhouse
2007-06-30 17:13                                           ` Rodolfo Giometti
2007-07-01  7:13                                             ` Stephen Rothwell
2007-07-01 19:24                                               ` Rodolfo Giometti
2007-07-10 16:01                                                 ` Lennart Sorensen
2007-07-10 16:36                                                   ` Rodolfo Giometti
2007-07-10 16:36                                                     ` David Woodhouse
2007-07-10 16:44                                                       ` Rodolfo Giometti
2007-07-10 22:03                                                     ` Lennart Sorensen
2007-07-11  8:06                                                       ` Rodolfo Giometti
2007-07-11 15:22                                                         ` Lennart Sorensen
2007-07-11 16:32                                                           ` Rodolfo Giometti
2007-07-11  1:18                                                   ` Roman Zippel
2007-07-11 15:24                                                     ` Lennart Sorensen
2007-07-11 16:35                                                       ` Rodolfo Giometti
2007-07-11 17:34                                                       ` Roman Zippel
2007-07-01 12:03                                             ` David Woodhouse
2007-07-01 19:27                                               ` Rodolfo Giometti
2007-07-03  9:48                                               ` Rodolfo Giometti
2007-07-03 13:09                                                 ` David Woodhouse
2007-07-03 13:21                                                   ` Rodolfo Giometti
2007-07-09 13:19                                                   ` Rodolfo Giometti
2007-07-10 16:05                                                     ` David Woodhouse
2007-07-10 16:38                                                       ` Rodolfo Giometti
2007-07-11  9:17                                                         ` David Woodhouse
2007-07-11 10:46                                                           ` Rodolfo Giometti
2007-06-30  8:38                                 ` Christoph Hellwig
2007-06-30 17:06                                   ` Rodolfo Giometti
2007-07-08  9:05                                 ` Oleg Verych
2007-07-09  9:16                                   ` Rodolfo Giometti
2007-07-09 10:56                                     ` Makefiles for GNU make (Re: [PATCH] LinuxPPS (with new syscalls API) - new version) Oleg Verych
2007-07-09 10:57                                       ` Rodolfo Giometti
     [not found] <fa.KzVWiacZsGdGiMxLldFOOPOdIEw@ifi.uio.no>
     [not found] ` <fa.TdDfr0FpGG8OjqtqWj6RNRusuU0@ifi.uio.no>
     [not found]   ` <fa.qT2j8q7/hQ2xVpeJCg7VGv+FvpI@ifi.uio.no>
     [not found]     ` <fa.RLNIoDXtVxFnlYMPJh2Q2+yDDOk@ifi.uio.no>
2007-06-26 23:33       ` [PATCH] LinuxPPS (with new syscalls API) Robert Hancock

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=20070627125802.GI13886@enneenne.com \
    --to=giometti@enneenne.com \
    --cc=akpm@linux-foundation.org \
    --cc=dwmw2@infradead.org \
    --cc=linux-kernel@vger.kernel.org \
    /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