diff options
author | Jes Sorensen <jes@sgi.com> | 2007-10-22 10:56:22 +1000 |
---|---|---|
committer | Rusty Russell <rusty@rustcorp.com.au> | 2007-10-23 15:49:48 +1000 |
commit | 891ff65ff50bb6affdaebb2cda3a4c58a6442b4d (patch) | |
tree | 737603293be49ce612e05fa49ec00a75e1b501a1 /drivers/lguest/hypercalls.c | |
parent | babed5c00225f109d6ebea368ad2deea2abcce32 (diff) | |
download | linux-891ff65ff50bb6affdaebb2cda3a4c58a6442b4d.tar.gz linux-891ff65ff50bb6affdaebb2cda3a4c58a6442b4d.tar.bz2 linux-891ff65ff50bb6affdaebb2cda3a4c58a6442b4d.zip |
Use copy_to_user() not put_user for struct timespec
Use copy_to_user() when copying a struct timespec to the guest -
put_user() cannot handle two long's in one go on a 64bit arch.
Signed-off-by: Jes Sorensen <jes@sgi.com>
Signed-off-by: Rusty Russell <rusty@rustcorp.com.au>
Cc: Jes Sorensen <jes@sgi.com>
Cc: Al Viro <viro@ftp.linux.org.uk>
Diffstat (limited to 'drivers/lguest/hypercalls.c')
-rw-r--r-- | drivers/lguest/hypercalls.c | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/drivers/lguest/hypercalls.c b/drivers/lguest/hypercalls.c index db6caace3b9c..5ecd60b54201 100644 --- a/drivers/lguest/hypercalls.c +++ b/drivers/lguest/hypercalls.c @@ -295,6 +295,6 @@ void write_timestamp(struct lguest *lg) { struct timespec now; ktime_get_real_ts(&now); - if (put_user(now, &lg->lguest_data->time)) + if (copy_to_user(&lg->lguest_data->time, &now, sizeof(struct timespec))) kill_guest(lg, "Writing timestamp"); } |