diff options
author | Rafael J. Wysocki <rjw@sisk.pl> | 2007-10-25 18:59:31 -0400 |
---|---|---|
committer | Len Brown <len.brown@intel.com> | 2008-02-01 18:30:52 -0500 |
commit | af508b34d27e3341287d89e0eae6752fdb1b873f (patch) | |
tree | b5d2a337d78dc25aadb02d481443d484e0dd368c /kernel/power/user.c | |
parent | aa6299926950c8dfe2fea638276cad6def092bc9 (diff) |
Hibernation: Introduce SNAPSHOT_GET_IMAGE_SIZE ioctl
Add a new ioctl, SNAPSHOT_GET_IMAGE_SIZE, returning the size of the (just
created) hibernation image, to the hibernation userland interface.
This ioctl is necessary so that the userland utilities using the interface need
not access the hibernation image header, owned by the kernel, in order to obtain
the size of the image.
Signed-off-by: Rafael J. Wysocki <rjw@sisk.pl>
Acked-by: Pavel Machek <pavel@ucw.cz>
Signed-off-by: Len Brown <len.brown@intel.com>
Diffstat (limited to 'kernel/power/user.c')
-rw-r--r-- | kernel/power/user.c | 18 |
1 files changed, 14 insertions, 4 deletions
diff --git a/kernel/power/user.c b/kernel/power/user.c index 5bd321bcbb75..88aac26e598a 100644 --- a/kernel/power/user.c +++ b/kernel/power/user.c | |||
@@ -133,7 +133,7 @@ static int snapshot_ioctl(struct inode *inode, struct file *filp, | |||
133 | { | 133 | { |
134 | int error = 0; | 134 | int error = 0; |
135 | struct snapshot_data *data; | 135 | struct snapshot_data *data; |
136 | loff_t avail; | 136 | loff_t size; |
137 | sector_t offset; | 137 | sector_t offset; |
138 | 138 | ||
139 | if (_IOC_TYPE(cmd) != SNAPSHOT_IOC_MAGIC) | 139 | if (_IOC_TYPE(cmd) != SNAPSHOT_IOC_MAGIC) |
@@ -210,10 +210,20 @@ static int snapshot_ioctl(struct inode *inode, struct file *filp, | |||
210 | image_size = arg; | 210 | image_size = arg; |
211 | break; | 211 | break; |
212 | 212 | ||
213 | case SNAPSHOT_GET_IMAGE_SIZE: | ||
214 | if (!data->ready) { | ||
215 | error = -ENODATA; | ||
216 | break; | ||
217 | } | ||
218 | size = snapshot_get_image_size(); | ||
219 | size <<= PAGE_SHIFT; | ||
220 | error = put_user(size, (loff_t __user *)arg); | ||
221 | break; | ||
222 | |||
213 | case SNAPSHOT_AVAIL_SWAP: | 223 | case SNAPSHOT_AVAIL_SWAP: |
214 | avail = count_swap_pages(data->swap, 1); | 224 | size = count_swap_pages(data->swap, 1); |
215 | avail <<= PAGE_SHIFT; | 225 | size <<= PAGE_SHIFT; |
216 | error = put_user(avail, (loff_t __user *)arg); | 226 | error = put_user(size, (loff_t __user *)arg); |
217 | break; | 227 | break; |
218 | 228 | ||
219 | case SNAPSHOT_GET_SWAP_PAGE: | 229 | case SNAPSHOT_GET_SWAP_PAGE: |